双指针&前缀和

acwing799最长连续不重复子序列

#include<bits/stdc++.h>
using namespace std;

const int N=1e5+10;
int n;
int q[N];
int cnt[N];

int main()
{
    std::ios::sync_with_stdio(0);
    std::cin.tie(0);

    cin>>n;
    for(int i=1;i<=n;i++)
        cin>>q[i];
    int res=0;
    for(int i=1,j=1;i<=n;i++)
    {
        cnt[q[i]]++;
        while(cnt[q[i]]>1)
        {
            cnt[q[j]]--;
            j++;
        }
        res=max(res,i-j+1);
    }
    cout<<res;
    return 0;
}

acwing795前缀和

#include<bits/stdc++.h>
using namespace std;

const int N=1e5+10;
int n,m;
int a[N],s[N];

int main()
{
    cin>>n>>m;
    for(int i=1;i<=n;i++)
    {
        cin>>a[i];
        s[i]=s[i-1]+a[i];
    }
    while(m--)
    {
        int l,r;
        cin>>l>>r;
        cout<<s[r]-s[l-1]<<'\n';
    }
    return 0;
}

acwing796子矩阵的和

#include<bits/stdc++.h>
using namespace std;

const int N=1010;
int n,m,k;
int q[N][N],s[N][N];

int main()
{
    cin>>n>>m>>k;
    for(int i=1;i<=n;i++)
    {
        for(int j=1;j<=m;j++)
        {
            cin>>q[i][j];
            s[i][j]=s[i-1][j]+s[i][j-1]-s[i-1][j-1]+q[i][j];
        }
    }
    while(k--)
    {
        int x1,y1,x2,y2;
        cin>>x1>>y1>>x2>>y2;
        cout<<s[x2][y2]-s[x1-1][y2]-s[x2][y1-1]+s[x1-1][y1-1]<<'\n';
    }
    return 0;
}

acwing800数组元素目标和

#include<bits/stdc++.h>
using namespace std;

const int N=1e5+10;
int n,m,x;
int a[N],b[N];

int main()
{
    cin>>n>>m>>x;
    for(int i=1;i<=n;i++) cin>>a[i];
    for(int i=1;i<=m;i++) cin>>b[i];
    for(int i=1,j=m;i<=n;i++)
    {
        while(j>=1&&a[i]+b[j]>x) j--;
        if(a[i]+b[j]==x)
        {
            cout<<i-1<<" "<<j-1<<endl;
            return 0;
        }
    }
    return 0;
}

A – B数对

#include<bits/stdc++.h>
using namespace std;

const int N=2e5+10;
int n,C;
int q[N];

int main()
{
    std::ios::sync_with_stdio(0);
    std::cin.tie(0);

    cin>>n>>C;
    for(int i=1;i<=n;i++)
    {
        cin>>q[i];
    }
    sort(q+1,q+n+1);
    long long cnt=0;
    for(int a=1,b1=1,b2=1;a<=n;a++)
    {
        while(b1<=a&&q[a]-q[b1]>=C)
        {
            b1++;
        }
        while(b2<=a&&q[a]-q[b2]>C)
        {
            b2++;
        }
        cnt+=b1-b2;
    }
    cout<<cnt<<endl;
    return 0;
}

递增三元组

#include<bits/stdc++.h>
using namespace std;

const int N=1e5+10;
int n;
int a[N],b[N],c[N];

int main()
{
    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++) cin>>c[i];

    sort(a+1,a+1+n);
    sort(b+1,b+1+n);
    sort(c+1,c+1+n);

    long long res=0;
    for(int i=1,IndexA=1,IndexC=1;i<=n;i++)
    {
        int B=b[i];
        while(IndexA<=n&&a[IndexA]<B) IndexA++;
        while(IndexC<=n&&c[IndexC]<=B) IndexC++;
        res+=(long long)(IndexA-1)*(n-IndexC+1);
    }
    cout<<res<<endl;
    return 0;
}

Diamond Collector S

#include<bits/stdc++.h>
using namespace std;

const int N=5e4+10;
int n,K;
int a[N];
int cnt_lr[N],cnt_rl[N];

int main()
{
    cin>>n>>K;
    for(int i=1;i<=n;i++)cin>>a[i];
    sort(a+1,a+1+n);
    for(int i=1,j=1;i<=n;i++)
    {
        while(j<=i&&a[i]-a[j]>K)j++;
        cnt_lr[i]=max(cnt_lr[i-1],i-j+1);
    }
    for(int i=n,j=n;i>=1;i--)
    {
        while(j>=i&&a[j]-a[i]>K)j--;
        cnt_rl[i]=max(cnt_rl[i+1],j-i+1);
    }
    int res=0;
    for(int i=1;i<=n-1;i++)
    {
        res=max(res,cnt_lr[i]+cnt_rl[i+1]);
    }
    cout<<res<<endl;
    return 0;
}
暂无评论

发送评论 编辑评论


				
|´・ω・)ノ
ヾ(≧∇≦*)ゝ
(☆ω☆)
(╯‵□′)╯︵┴─┴
 ̄﹃ ̄
(/ω\)
∠( ᐛ 」∠)_
(๑•̀ㅁ•́ฅ)
→_→
୧(๑•̀⌄•́๑)૭
٩(ˊᗜˋ*)و
(ノ°ο°)ノ
(´இ皿இ`)
⌇●﹏●⌇
(ฅ´ω`ฅ)
(╯°A°)╯︵○○○
φ( ̄∇ ̄o)
ヾ(´・ ・`。)ノ"
( ง ᵒ̌皿ᵒ̌)ง⁼³₌₃
(ó﹏ò。)
Σ(っ °Д °;)っ
( ,,´・ω・)ノ"(´っω・`。)
╮(╯▽╰)╭
o(*////▽////*)q
>﹏<
( ๑´•ω•) "(ㆆᴗㆆ)
😂
😀
😅
😊
🙂
🙃
😌
😍
😘
😜
😝
😏
😒
🙄
😳
😡
😔
😫
😱
😭
💩
👻
🙌
🖕
👍
👫
👬
👭
🌚
🌝
🙈
💊
😶
🙏
🍦
🍉
😣
Source: github.com/k4yt3x/flowerhd
颜文字
Emoji
小恐龙
花!
上一篇
下一篇