标签:blog http io os ar for sp div 2014
> <看了一下觉得挺难的...除了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)[未填]
标签:blog http io os ar for sp div 2014
原文地址:http://www.cnblogs.com/polebug/p/4034402.html