2019牛客暑期多校训练营(第十场)
生活随笔
收集整理的這篇文章主要介紹了
2019牛客暑期多校训练营(第十场)
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
Problem A?Blackjack
?
題意:
題解:
C++版本一
?
Problem B?Coffee Chicken
?
題意:
題解:
C++版本一
?
Problem C?Gifted Composer
?
題意:
題解:
C++版本一
?
Problem D?Han Xin and His Troops
?
題意:
題解:
C++版本一
?
Problem E?Hilbert Sort
?
題意:
題解:
C++版本一
?
Problem F?Popping Balloons
?
題意:
題解:
C++版本一
#include<bits/stdc++.h> #define ll long long #define rep(i,a,b) for(int i=a;i<=b;i++) #define per(i,a,b) for(int i=a;i>=b;i--) using namespace std; const int MAXN = 1e5+5; const double eps = 1e-9; int n,m,x,y; int num[MAXN]; vector<int>v[MAXN<<2]; struct node{int l,r,val; }a[MAXN<<2]; void build(int rt,int l,int r){a[rt].l=l,a[rt].r=r;if(l==r){a[rt].val=num[l]+num[l+m]+num[l+2*m];return;}int mid=(l+r)>>1;build(rt<<1,l,mid);build(rt<<1|1,mid+1,r);a[rt].val=max(a[rt<<1].val,a[rt<<1|1].val); } void update(int rt,int x,int val){if(a[rt].l==a[rt].r&&a[rt].l==x){a[rt].val+=val;return;}int mid=(a[rt].l+a[rt].r)>>1;if(x<=mid)update(rt<<1,x,val);else update(rt<<1|1,x,val);a[rt].val=max(a[rt<<1].val,a[rt<<1|1].val); } int main() {while(~scanf("%d%d",&n,&m)){rep(i,0,1e5)v[i].clear(),num[i]=0;int ans=0;rep(i,1,n){scanf("%d%d",&x,&y);v[x].push_back(y);num[y]++;}build(1,0,1e5);rep(i,0,1e5){int temp=v[i].size()+v[i+m].size()+v[i+2*m].size();int len=v[i].size();rep(j,0,len-1){int y=v[i][j];update(1,y,-1);if(y-m>=0)update(1,y-m,-1);if(y-2*m>=0)update(1,y-2*m,-1);}len=v[i+m].size();rep(j,0,len-1){int y=v[i+m][j];update(1,y,-1);if(y-m>=0)update(1,y-m,-1);if(y-2*m>=0)update(1,y-2*m,-1);}len=v[i+2*m].size();rep(j,0,len-1){update(1,y,-1);if(y-m>=0)update(1,y-m,-1);if(y-2*m>=0)update(1,y-2*m,-1);}ans=max(ans,temp+a[1].val);len=v[i].size();rep(j,0,len-1){int y=v[i][j];update(1,y,1);if(y-m>=0)update(1,y-m,1);if(y-2*m>=0)update(1,y-2*m,1);}len=v[i+m].size();rep(j,0,len-1){int y=v[i+m][j];update(1,y,1);if(y-m>=0)update(1,y-m,1);if(y-2*m>=0)update(1,y-2*m,1);}len=v[i+2*m].size();rep(j,0,len-1){update(1,y,1);if(y-m>=0)update(1,y-m,1);if(y-2*m>=0)update(1,y-2*m,1);}}printf("%d\n",ans);} }Problem G?Road Construction
?
題意:
題解:
C++版本一
?
Problem H?Stammering Chemists
?
題意:
題解:
C++版本一
?
Problem I?Travel Dream
?
題意:
題解:
C++版本一
?
Problem J?Wood Processing
?
題意:
題解:
C++版本一
?
?
總結
以上是生活随笔為你收集整理的2019牛客暑期多校训练营(第十场)的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 2019牛客暑期多校训练营(第九场)
- 下一篇: 企业级 WEB 报表工具——FineRe