日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

2019牛客暑期多校训练营(第十场)

發布時間:2024/10/5 编程问答 25 豆豆
生活随笔 收集整理的這篇文章主要介紹了 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牛客暑期多校训练营(第十场)的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。