首页 > 其他分享 >《看了受制了》第二十九天,7道题,合计148道题

《看了受制了》第二十九天,7道题,合计148道题

时间:2023-09-28 23:33:06浏览次数:47  
标签:道题 val int ll tr 148 受制 flag include

2023年9月28日
好尴尬啊,好尴尬啊,怎么就想不到呢?今天的CD思路都是来源于知乎大佬。
【----->此篇博客解析<-----】

Acwing1275 最大数

题目理解

线段树,板子题。但是需要转化!!

  • 每次添加一个数,看作在flag + 1的位置上,修改一个数
  • 然后query是求l 到 flag的最大值
  • 所以pushup的操作就是最大值

代码实现

ll m, p;
ll flag = 0;
struct Node
{
    int l, r;
    ll val;
}tr[N * 4];

void pushup(int u){tr[u].val = max(tr[u << 1].val, tr[u << 1 | 1].val);}

void build(int u, int l,int r)
{
    if(l == r) tr[u] = {l, r, 0};
    else{

        tr[u] = {l , r};
        int mid = (l + r) >> 1;

        build(u << 1, l, mid), build(u << 1 | 1, mid + 1, r);
        pushup(u);
    }
}


ll query(int u, ll l, ll r)
{
    if(tr[u].l >= l && tr[u].r <= r) return tr[u].val;

    ll val = LLONG_MIN;
    int mid = (tr[u].l + tr[u].r) >> 1;
    if(l <= mid) val = query(u << 1, l, r);
    if(r > mid) val = max(query(u << 1 | 1, l, r), val);

    return val;
}


void modify(int u, int a, ll val)
{
    if(tr[u].l == tr[u].r) tr[u].val = val;
    else{
        int mid = (tr[u].l + tr[u].r) >> 1;

        if(a <= mid) modify(u << 1, a, val);
        else modify(u << 1 | 1, a, val);

        pushup(u);
    }
}

ll q = 0;
int main() {

    cin >> m >> p;

    build(1, 1, m);

    while(m -- )
    {
        string op;
        ll l;
        cin >> op >> l;
        if(op == "A"){
            flag++;
            modify(1, flag, (l + q) % p);
        }else{
            q = query(1, flag - l + 1, flag);
            cout << q << endl;
        }
    }


    return 0;
}

Acwing241 楼兰图腾

题目理解

树状数组板子题。

  • 左边比它小的数乘右边比它小的数
  • 左边比他大的数乘右边比它大的数
  • 两个求和

代码实现

const int N  = 200000 + 10;

ll tr[N], s[N];
ll n;
ll low[N], hig[N];
ll lowbit(ll a){return a & -a;}
ll add(ll a, ll v){for(int i = a; i <= N; i += lowbit(i)) tr[i] += v;}
ll sum(ll a)
{
    ll val = 0;
    for(int i = a; i ; i -= lowbit(i)) val += tr[i];
    return val;
}

int main() {

    cin >> n;

    for(int i = 1; i <= n; i++) cin >> s[i];

    // 前面有多少个
    for(int i = 1; i <= n; i++)
    {
        int b = s[i];

        hig[i] = sum(n) - sum(b);
        low[i] = sum(b - 1);
        add(b, 1);
    }


    memset(tr, 0, sizeof tr);
    ll resl = 0, resr = 0;

    for(int i = n; i >= 1; i--)
    {
        int b = s[i];

        resr += hig[i] * (sum(n) - sum(b));
        resl += low[i] * (sum(b - 1));
        add(b, 1);
    }

    cout << resr << " " << resl;

    return 0;
}

Acwing1270 数列区间最大值

题目理解

就是线段树板子!pushup是操作最大值

代码实现

#include <iostream>
#include <algorithm>
#include <climits>
#include <unordered_map>
#include <cstring>
#include <cstdio>
#include <cmath>
#include <vector>
#include <queue>
#include <map>
#include <set>
#define x first
#define y second
using namespace std;
typedef long long ll;
typedef pair<int, int> PII;

const int Mod = 1e9 + 7;
const int INF = 0x3f3f3f3f;

ll qmi(ll a, ll b){
    ll res = 1;
    while(b)
    {
        if(b & 1) res = res * a % Mod;
        a = a * a % Mod;
        b >>= 1;
    }
    return res;
}

ll inv(ll p){ return qmi(p, Mod - 2);}
ll mo(ll p){ return (p % Mod + Mod) % Mod;}

const int N = 1e5 + 10;
int n, m;
int w[N];
struct Node
{
    int l, r;
    int val;    
}tr[N * 4];

void pushup(int u)
{
    tr[u].val = max(tr[u << 1].val, tr[u << 1 | 1].val);
}

void build(int u, int l,int r)
{
    if(l == r) tr[u] = {l, r, w[r]};
    else{
        tr[u] = {l, r};
        int mid = (l + r) >> 1;
        build(u << 1, l, mid), build(u << 1 | 1, mid + 1, r);
        pushup(u);
    }
}

int query(int u, int l, int r)
{
    if(tr[u].l >= l && tr[u].r <= r) return tr[u].val;

    int mid = (tr[u].l + tr[u].r) >> 1;
    int val = INT_MIN;

    if(l <= mid) val = query(u << 1, l, r);
    if(r > mid) val = max(val, query(u << 1 | 1, l, r));

    return val;
}

int main() {

    scanf("%d%d", &n, &m);

    for(int i = 1; i <= n; i++) scanf("%d", &w[i]);

    build(1, 1, n);

    while(m -- )
    {
        int l, r;
        scanf("%d%d", &l, &r);
        printf("%d\n", query(1, l, r));
    }

    return 0;
}

Div.3 Round891 A Array Colorinig

题目理解

只要奇数的个数是偶数即可。

代码实现

void solve()
{
    int n;
    cin >> n;
    int cnt = 0;
    for(int i = 1; i <= n; i++)
    {
        int b;
        cin >> b;
        if(b%2) cnt++;
    }
    if(cnt % 2) cout << "NO" << endl;
    else cout << "YES" << endl;
    return;
}

Div.3 Round891 B Maximum Rounding

题目理解

从左往右扫,可以进位就把后面的都变0,前面的加一,然后开始往前扫,能进位就进!
特判当j == 0的时候,因为第一个的前面没有会SF

代码实现

void solve()
{
    string s;
    cin >> s;
    int flag = INT_MAX;
    for (int i = 0; i < s.size(); i++)
    {
        if (s[i] >= '5')
        {
            flag = i;
            s[i] = '0';
            if (i - 1 == -1)
            {
                cout << 1;
                string str(s.size(), '0');
                cout << str << endl;
                return;
            }
            s[i - 1]++;
            for (int j = i - 1; j >= 0; j--)
                if (s[j] >= '5')
                {
                    flag = i;
                    s[j] = '0';
                    if (j - 1 == -1)
                    {
                        cout << 1;
                        string str(s.size(), '0');
                        cout << str << endl;
                        return;
                    }
                    s[j - 1]++;
                }
            break;
        }
    }

    if (s[0] >= '5' || s[0] == '0')
    {
        cout << 1;
        string str(s.size(), '0');
        cout << str << endl;
    }
    else
    {
        for (int i = 0; i < s.size(); i++)
            if (i < flag)
                cout << s[i];
            else
                cout << 0;
        cout << endl;
    }
    return;
}

Div.3 Round891 C Assembly via Minimums

题目理解

这个题,完全没想到!哦不对,想到20%,可惜。我们来看下大佬的思路。博客链接放到了最顶上。

自己理解

  • 因为那个出现的次数,所以我们就可以按照次数进行放置
  • 用到了优先队列,就是可以排个序,其实我们也能全读进去然后排序
  • 最重要的就是从小到大的出现次数为n - 1 \ n - 2 \ n - 3 ... 这个

代码实现

const int N = 1e3 + 10;

void solve()
{
    int n;
    priority_queue<int, vector<int>, greater<int>> q;
    cin >> n;

    for(int i = 1; i <= n * (n - 1) / 2; i++)
    {
        int t;
        cin >> t;
        q.push(t);
    }

    for(int i = 1; i < n; i++)
    {
        int t = q.top();
        int w = n - i;
        while(w--) q.pop();
        if(i != n - 1)
            cout << t << " ";
        else
            cout << t << " " << t;
    }
    cout << endl;
    return;
}

Div.3 Round891 D Strong Vertices

题目理解!大佬思路!!

代码实现

const int N = 2e5 + 10;
int a[N], b[N];
void solve()
{
    int n;
    pair<int, int> q[N];
    cin >> n;

    for(int i = 1; i <= n; i++)
        cin >> a[i];

    for(int i = 1; i <= n; i++)
        cin >> b[i];

    for(int i = 1; i <= n; i++)
        q[i].y = i, q[i].x = a[i] - b[i];
    
    sort(q + 1, q + 1 + n);
    int m = q[n].x;

    vector<int> vec;
    for(int i = 1; i <= n; i++)
        if(q[i].x == m)
            vec.push_back(q[i].y);
    
    cout << vec.size() << endl;
    for(int i = 0; i < vec.size(); i++)  cout << vec[i] << " ";
    
    cout << endl;
    return;
}

标签:道题,val,int,ll,tr,148,受制,flag,include
From: https://www.cnblogs.com/wxzcch/p/17736663.html

相关文章

  • 加训日记 Day8——关于cf一道题调了半天这件事
    Day8,9.28  ·国庆假期前狠狠刷cf  ·把之前比赛的题目基本上都补了(牛客的没来得及补)  ·这一个星期日均四道题,确实挺不错的  ·思维还是跟不上捏......
  • [Go 夜读 第 148 期] Excelize 构建 WebAssembly 版本跨语言支持实践
    Excelize是Go语言编写的用于操作电子表格文档的基础库,支持XLAM/XLSM/XLSX/XLTM/XLTX等多种文档格式,高度兼容带有样式、图片(表)、透视表、切片器等复杂组件的文档,并提供流式读写支持,用于处理包含大规模数据的工作簿。可应用于各类报表平台、云计算、边缘计算等系统......
  • 《看了受制了》第二十五天吗,5道题,合计119道题
    2023年9月24日今天下午,把atcoder翻译的弄成了一个ChatGpt的接口版本。优化了很多。牛客周赛13矩阵转置置题面理解就是语法,倒着输出即可。代码实现#include<iostream>#include<algorithm>#include<unordered_map>#include<cstring>#include<cstdio>#include<vect......
  • 《看了受制了》第二十四天,7道题,合计114道题
    2023年9月23日今天周六,尽力做了做,虽然Acwing没能AK。。没读懂题。Acwing5152简单输出题目理解基础语法代码实现#include<iostream>#include<algorithm>#include<unordered_map>#include<cstring>#include<cstdio>#include<vector>#include<queue>#i......
  • 《看了受制了》第二十三天,4道题,合计107道题
    2023年9月22日哎,再一次意识到弱小。。Acwing1127香甜的黄油题目理解求n遍最短路,求出每个点到某个点到所有牧场的最短路即可。代码实现#include<iostream>#include<algorithm>#include<cstring>#include<cstdio>#include<vector>#include<queue>#include<unord......
  • 《看了受制了》第二十天,7道题,合计97道
    2023年9月19日牛客,ACWING图论!思前想后,这个图论一定要从0到0.1!!!牛客周赛游游的字符串题目理解输出k个you,然后剩下的都是o即可代码实现#include<iostream>#include<algorithm>#include<cstring>#include<vector>#include<queue>#include<map>#definexfirst#def......
  • 《看了受制了》第二十天,6道题,合计90道题
    2023年9月18日今天上午写了Atcoder的翻译,以后对于我这种菜鸡来说,多多少少有点用了。前两个题是贪心,第三个是BFS。Acwing908最大不相交区间数量题目理解全部按右端点进行排序然后如果下一个点的左,比我的右端点还大,那么就肯定不在一个区间然后更新目前的右端点即可代码实......
  • 1N4148(T4)-ASEMI贴片开关二极管1N4148(T4)
    编辑:ll1N4148(T4)-ASEMI贴片开关二极管1N4148(T4)型号:1N4148(T4)品牌:ASEMI封装:SOD-123正向电流:150mA反向电压:100V引线数量:2芯片个数:1芯片尺寸:102MIL漏电流:10ua恢复时间:浪涌电流:300mA芯片材质:正向电压:1.0V封装尺寸:如图特性:迷你贴片开关二极管工作结温:-55℃~150℃包装方式:500/箱1N4148(T4)-AS......
  • 1N4148(T4)-ASEMI贴片开关二极管1N4148(T4)
    编辑:ll1N4148(T4)-ASEMI贴片开关二极管1N4148(T4)型号:1N4148(T4)品牌:ASEMI封装:SOD-123正向电流:150mA反向电压:100V引线数量:2芯片个数:1芯片尺寸:102MIL漏电流:10ua恢复时间:浪涌电流:300mA芯片材质:正向电压:1.0V封装尺寸:如图特性:迷你贴片开关二极管工作结温:-55℃~150℃包装方......
  • 《看了受制了》第十九天,7道题,合计84道题
    2023年9月17日今天晚上打了牛客的周赛。题目不是很难的题目,哎,最后一题是位运算,不会啊。。。异或和。。今晚还发现了一个up主,同是21级,大二摘金,我大二哎。每次都会感到世界的层次,认识到自己的弱小。。。而且也发现自己的一些观念上的错误。牛客周赛12小美种树题目理解这个题和......