首页 > 代码库 > 2014-10-18 noip提高组模拟赛(codecomb)[未填]

2014-10-18 noip提高组模拟赛(codecomb)[未填]

> <看了一下觉得挺难的...除了T2

T1只想到了找环,> <倍增的思想没有学过,所以看题解看得雨里雾里的(最近真的打算学一下!)

T2贪心..很容易看出的

T3感觉题目没有怎么看懂...> <正解居然是树形dp 果然不太会

T4蒟蒻> <我连最小子矩阵都不会求T_T其他更不用说了

虽然没有参加比赛,但感觉自己到不了200(hzwer说没有200应该去参加普及组QAQ)

 

题目出的挺好的,觉得noip极有可能出现T1T2T3,所以在此mark

 

而且T1以为是模拟,还妄想这可以一遍处理出所有的环,和各个数之间的关系(> <结果自己把自己绕进去了,因为根本不可以!)

然后后面改了暴力,每问一次就处理一次;

正解没看懂QAQ..应该是不太懂思想的缘故

暴力:

#include <cstdio>#include <cstring>#include <algorithm>#include <iostream>using namespace std;const int maxn=100005;int n,m,x;long long k;int a[maxn];bool v[maxn];int main(){	scanf("%d%d",&n,&m);	for(int i=1;i<=n;i++){		scanf("%d",&a[i]);	}	for(int i=1;i<=m;i++){		cin>>x>>k;	    for(int i=1;i<=n;i++) v[i]=0;	    int temp;		for(int i=x;!v[i];i=a[i]){	    	v[i]=1;	    	temp=a[i];	    }	    while(k && x!=temp){	    	x=a[x];	    	k--;	    }	    if(k){	    	int cnt=1;	    	while(a[temp]!=x){	    		cnt++;	    		temp=a[temp];	    	}	    	k%=cnt;	    }		while(k--) x=a[x];		cout<<x;	}	return 0;}

  

 

T2:找min:一直找最小的那个,直到a[i]-x+1小于0,就找次小的,以此类推;

求max,也是一样的,一直到最大的那个,直到次大的比之前最大的大,就找次大的;

这个模拟,可以用上priority_queue;

#include <cstdio>#include <cstring>#include <algorithm>#include <iostream>#include <queue>using namespace std;const int maxn=1000001;int n,m;int a[maxn];long long minx,maxx;priority_queue<int> q;int main(){    scanf("%d%d",&n,&m);    for(int i=1;i<=n;i++){    	scanf("%d",&a[i]);    	q.push(a[i]);    }    sort(a+1,a+n+1);    int temp=1;	for(int i=1;i<=m;i++){    	int t=q.top();    	q.pop();    	maxx+=t;    	q.push(t-1);    	while(!a[temp]) temp++;    	minx+=a[temp];    	a[temp]--;    }    cout<<maxx<<" "<<minx;	return 0;}

  

2014-10-18 noip提高组模拟赛(codecomb)[未填]