Beaver's Calculator coderforces 70A1 蓝桥杯
2017-02-02 21:02
253 查看
Beaver's Calculator coderforces 70A1
这道题贪心 思路简单 但是方法对于我来说比较巧了
题解看源码
#include<stdio.h> #include<algorithm> using namespace std; struct type{long x,y,z;}p[300000]; bool cmp(type x,type y){ if (x.x==y.x) return (x.y<y.y || (x.y==y.y && x.z<y.z)); else return x.x<y.x; } long long n,k,a,x,y,m; long long ans,tot,t,b; long i,j; //这道题我用的是用队列模拟序列的固定顺序 每次取出对列头 但是超时了 //这个用的是用一个标记然后用标记排序就先当于我上面那个 //但是想不通的是 为什么对每个科学家的ans是对的 //按照上面的思路 就是每个科学家最前面的 因为是用优先队列排列的所以是有序的 //这个时候取出最小 的 之后无非就是两个情况 一种是原来那个科学家继续取 另一种就是其他科学家那里取 //如果是第二种的话 因为之前是最小的所以取出来就是大小有序的 那么就只剩第一种了 就是一个科学家有序的对数了 //为什么是t 这里排序了逆序的对数 //没想到贪心也这么难 //整个题目的核心就是 怎样排序 且保证每个科学家的序列的相对顺序是固定不变的 //也就是用t分块 t相等就可以按cost排序 也就是一块 每一块与每一块的间隔就是逆序的 int main(){ scanf("%I64d",&n); for (i=1;i<=n;i++){ scanf("%I64d%I64d%I64d%I64d%I64d",&k,&a,&x,&y,&m); for(t=0,j=1;j<=k;j++){ if (tot<=2e5) p[++tot]=(type){t,a,i}; b=(a*x+y)%m; if (b<a && j!=k) t++;//t来标记块 块内就不用在考虑相对的顺序了 因为每块的都是按有序t分的 a=b; } ans=max(ans,t); } printf("%I64d\n",ans); if (tot<=2e5){ sort(p+1,p+tot+1,cmp); for (i=1;i<=tot;i++) printf("%I64d %I64d\n",p[i].y,p[i].z); } return 0; }
相关文章推荐
- Beaver's Calculator(蓝桥杯 算法训练)sort排序
- BF Calculator CodeForces - 784G
- 蓝桥杯- 算法训练-Beaver's Calculator
- Educational Codeforces Round 6 B. Grandfather Dovlet’s calculator (分解数字个位)
- Coderforces Next_Round
- Coderforces Lucky Division
- Coderforces Queue at the School
- coderforces 508A 易错
- Coderforces 396A
- 文章标题 Coderforces 343D : Water Tree(dfs序+线段树)
- 【DP】coderforces 567F
- 文章标题 Coderforces 382C :Arithmetic Progression(代码能力+细心分类)
- Coderforces String Task
- Coderforces 508B 简单贪心
- coderforces 138CMushroom Gnomes - 2线段树
- coderforces 22C 构图水题
- coderforces 701A Cards
- Coderforces 730H 730G
- 文章标题 CoderForces 298A: Snow Footprints(水)
- Coderforces Domino piling