Codeforces Round #737 (Div. 2)

A
剛開始其實並不會而後看了看樣例發現本身會了。
大概就是把最大的拿出來而後剩下的放一塊兒,正確性易證。
code:spa

using namespace std;
int T,n,x;ll Maxn,ToT;
int main(){
	scanf("%d",&T);while(T--){
		scanf("%d",&n);Maxn=-1e18;ToT=0;for(int i=1;i<=n;i++)scanf("%d",&x),Maxn=max(Maxn,x),ToT+=x;printf("%.8lf\n",Maxn+(ToT-Maxn)*1.0/(n-1));
	}
}

B
被假作法卡了半天。
排好序的序列是固定的因此能夠算出來,而後對應原序列的位置也能夠算出來。
而後看連續段就行了。
code:code

int T,n,A[N+5],Ans,k,Id[N+5];I bool cmp(int x,int y){return A[x]<A[y];}
int main(){
	freopen("1.in","r",stdin);
	re int i,j;scanf("%d",&T);while(T--){
		Ans=0;scanf("%d%d",&n,&k);for(i=1;i<=n;i++)scanf("%d",&A[i]),Id[i]=i;sort(Id+1,Id+n+1,cmp);for(i=2;i<=n;i++) Ans+=(Id[i]!=Id[i-1]+1);printf("%s\n",Ans+1<=k?"YES":"NO");
	}
}

C
這個C比D難好吧儘管都很板子。
由於位運算的性質因此咱們確定枚舉一位不一樣,而後高位相同低位隨意。
低位隨意隨便搞搞,高位相同咱們設\(F(x,n)\)表示\(x\)\(n\)個數知足題面式子相等的答案。
若是咱們設\(G(x,n)\)\(x\)\(n\)個數異或出來和與出來都是\(0\)的方案數,那麼\(G(x)=2^{n(x-1)}\)
而後\(F(x)=\sum\limits_{i=0}^{x}{C_{x}^{i}G(x-i)}\)而後二項式定理一下就行了。
code:ci

using namespace std;
int n,m,k,T,x,y,z;ll B[N+5][2],Ans,now;
I ll mpow(ll x,int y=mod-2){ll Ans=1;while(y) y&1&&(Ans=Ans*x%mod),y>>=1,x=x*x%mod;return Ans;}
I ll calc(int x,int y){now=mpow(2,x-1)-(n%2==0)*2+mod;return mpow(now+1,y);}
int main(){
	freopen("1.in","r",stdin);
	re int i;scanf("%d",&T);while(T--){
		Ans=0;scanf("%d%d",&n,&k);if(n%2==0){
			for(i=k-1;~i;i--) Ans+=calc(n,k-i-1)*mpow(mpow(2,n),i)%mod;
		}Ans+=calc(n,k);printf("%lld\n",Ans%mod);
	}
}

D
\(dp_i\)爲到\(i\)行最多能保留的行數。
而後確定是離散之後找一個有一列相同的最大轉移,而後這個放在線段樹上轉移就行了。
code:get

using namespace std;
int n,m,k,x[N+5],y[N+5],z[N+5],dp[N+5],nows[N+5<<1],tots[N+5<<1],las[N+5],Fl[N+5],ToT;
struct Ques{int x,y;};vector<Ques> G[N+5];
struct pai{int w,id;pai operator +(const pai &B)const{return w>B.w?(pai){w,id}:B;};}F[N+5<<4],Sum[N+5<<4],Cl,now;
I void pushF(int now,pai z){F[now]=F[now]+z;Sum[now]=Sum[now]+z;}I void push(int x){pushF(x<<1,F[x]);pushF(x<<1|1,F[x]);F[x]=Cl;}I void Up(int now){Sum[now]=Sum[now<<1]+Sum[now<<1|1];}
I void insert(int x,int y,pai z,int l=1,int r=2*m,int now=1){
	if(x<=l&&r<=y) return pushF(now,z);push(now);int m=l+r>>1;x<=m&&(insert(x,y,z,l,m,now<<1),0);y>m&&(insert(x,y,z,m+1,r,now<<1|1),0);Up(now);
}
I pai find(int x,int y,int l=1,int r=m*2,int now=1){
	if(x<=l&&r<=y) return  Sum[now];push(now);int m=l+r>>1;pai Ans=Cl;x<=m&&(Ans=Ans+find(x,y,l,m,now<<1),0);y>m&&(Ans=Ans+find(x,y,m+1,r,now<<1|1),0);return Ans;
}
int main(){
	freopen("1.in","r",stdin);
	re int i,j;scanf("%d%d",&n,&m);for(i=1;i<=m;i++) scanf("%d%d%d",&z[i],&x[i],&y[i]),nows[i*2-1]=x[i],nows[i*2]=y[i];sort(nows+1,nows+m*2+1);for(i=1;i<=m*2;i++) tots[i]=tots[i-1]+(nows[i]!=nows[i-1]);
	for(i=1;i<=m;i++)x[i]=tots[lower_bound(nows+1,nows+2*m+1,x[i])-nows],y[i]=tots[lower_bound(nows+1,nows+2*m+1,y[i])-nows],G[z[i]].push_back((Ques){x[i],y[i]});
	for(i=1;i<=n;i++){
		now=Cl;for(j=0;j<G[i].size();j++) now=now+find(G[i][j].x,G[i][j].y);dp[i]=now.w+1;las[i]=now.id;dp[i]>dp[ToT]&&(ToT=i);for(j=0;j<G[i].size();j++) insert(G[i][j].x,G[i][j].y,(pai){dp[i],i});
	}printf("%d\n",n-dp[ToT]);while(ToT) Fl[ToT]=1,ToT=las[ToT];for(i=1;i<=n;i++) !Fl[i]&&(printf("%d ",i));
}

E
考慮一種方法,若是king和queen的行和列之差都爲奇數,那麼queen能夠先肯定左上,右上,左下,右下一個方向,而且按照king的方案不改變奇偶性地夾過去,一直夾到邊爲之,
這個是要\(32\)次詢問的。
而後分別改變行和列的奇偶性就能夠獲得一個\(32*4+3\)的作法,然而並不能被卡掉。
code:string

using namespace std;
int T,n,m,k,flag,x,y,z,nowx,nowy,Fl;string a,B[N+5]={"Right", "Left", "Up", "Down", "Down-Right", "Down-Left", "Up-Left", "Up-Right","Done"};
I int Y(string a){return (a==B[0])||(a==B[1])||(a==B[4])||(a==B[5])||(a==B[6])||(a==B[7]);}
I int X(string a){return (a==B[2])||(a==B[3])||(a==B[4])||(a==B[5])||(a==B[6])||(a==B[7]);}
I void Over(string a){if(a==B[8])Fl=1;}
I void Out(){cout<<nowx<<" "<<nowy<<endl;}
I void push(){
	flag=0;while(!flag){
		cin>>a;Over(a);if(Fl) return;if(X(a)){
			if(nowx==8) {nowx--;flag=1;}else nowx++;
		}
		if(Y(a)){
			if(nowy==8) {nowy--;flag=1;}else nowy++;
		}Out();
	}
	flag=0;while(!flag){
		cin>>a;Over(a);if(Fl) return;if(X(a)){
			if(nowx==1) {nowx++;flag=1;}else nowx--;
		}
		if(Y(a)){
			if(nowy==8) {nowy--;flag=1;}else nowy++;
		}Out();
	}
	flag=0;while(!flag){
		cin>>a;Over(a);if(Fl) return;if(X(a)){
			if(nowx==1) {nowx++;flag=1;}else nowx--;
		}
		if(Y(a)){
			if(nowy==1) {nowy++;flag=1;}else nowy--;
		}Out();
	}
	flag=0;while(!flag){
		cin>>a;Over(a);if(Fl) return;if(X(a)){
			if(nowx==8) {nowx--;flag=1;}else nowx++;
		}
		if(Y(a)){
			if(nowy==1) {nowy++;flag=1;}else nowy--;
		}Out();
	}
}
int main(){
	scanf("%d",&T);while(T--){
		Fl=0;printf("%d %d\n",nowx=4,nowy=4);fflush(stdout);
	    push();if(Fl) continue;cin>>a;Over(a);if(Fl) continue;if(!X(a)) {if(nowx==8)nowx--;else nowx++;}if(Y(a)){if(nowy==8) nowy--;else nowy++;}if(X(a)&&!Y(a)){if(nowx>=7) nowx-=2;else nowx+=2;}Out();
	    push();if(Fl) continue;cin>>a;Over(a);if(Fl) continue;if(X(a)) {if(nowx==8)nowx--;else nowx++;}if(!Y(a)){if(nowy==8) nowy--;else nowy++;}if(!X(a)&&Y(a)){if(nowx>=7) nowx-=2;else nowx+=2;}Out();
	    push();if(Fl) continue;cin>>a;Over(a);if(Fl) continue;if(!X(a)) {if(nowx==8)nowx--;else nowx++;}if(Y(a)){if(nowy==8) nowy--;else nowy++;}if(X(a)&&!Y(a)){if(nowx>=7) nowx-=2;else nowx+=2;}Out();push();if(Fl) continue;
	}
}
相關文章
相關標籤/搜索