ural 1144. The Emperor's Riddle
来源:互联网 发布:淘宝权女友辣椒和静雯 编辑:程序博客网 时间:2024/04/27 23:02
06年的论文题
玄学!!!!
玄学!!!!
玄学!!!!
重要的事情重复O(玄学)遍
写完这题我整个人都不好了
一开始由于很无脑地用vector,结果死活卡在第7个点,无限TLE。
没办法看了下别人的,卧槽贪心+玄学?果然纯玄学过不去啊
于是改了一下,顺便优化了下常数就过了。
再也不写玄学题了QAQ
#include<iostream>#include<cstdio>#include<cstring>#include<vector>#include<algorithm>#include<queue>#include<ctime>#include<cstdlib>#define mk(i,j) make_pair(i,j)using namespace std;const int N=10000+5;const int M=1000+5;int v[N],rk[M],to[M],tmp[N],s[2][M],sum[M],belong[N],tag[N];priority_queue<pair<int,int> >gold,gen;int n,m;int check(){for(int i=1;i<=m;i++)sum[i]=0;for(int i=1;i<=n;i++)sum[belong[i]]+=v[i];int mx=sum[1],mi=sum[1];for(int i=2;i<=m;i++)mx=max(mx,sum[i]),mi=min(mi,sum[i]);return mx-mi;}bool cmp1(int a,int b){return s[0][a]<s[0][b];}bool cmp2(int a,int b){return s[1][a]>s[1][b];}vector<int>mag[M];int main(){//freopen("a.in","r",stdin);srand(time(0));int k;scanf("%d%d%d",&n,&m,&k);for(int i=1;i<=n;i++)scanf("%d",&v[i]);for(int i=1;i<=m;i++)gen.push(mk(-sum[i],i));for(int i=1;i<=n;i++)gold.push(mk(v[i],i));for(int i=1;i<=n;i++){int u=gen.top().second,t=gold.top().second;gen.pop();gold.pop();sum[u]+=v[t];belong[t]=u;gen.push(mk(-sum[u],u));}int ans;while((ans=check())>k){for(int i=1;i<=n;i++)tag[i]=rand()&1;for(int t=0;t<2;t++)for(int i=1;i<=m;i++)s[t][i]=0;for(int i=1;i<=n;i++)s[tag[i]][belong[i]]+=v[i];for(int t=0;t<2;t++){for(int i=1;i<=m;i++)rk[i]=i;if(t==0)sort(rk+1,rk+1+m,cmp1);else sort(rk+1,rk+1+m,cmp2);for(int i=1;i<=m;i++)to[rk[i]]=i;for(int i=1;i<=n;i++)if(tag[i]==t)tmp[i]=to[belong[i]];}for(int i=1;i<=n;i++)belong[i]=tmp[i];}printf("%d\n",ans);for(int i=1;i<=n;i++)mag[belong[i]].push_back(i);for(int i=1;i<=m;i++){for(int j=0;j<mag[i].size();j++)printf("%d ",mag[i][j]);putchar('\n');}return 0;}
0 0
- ural 1144. The Emperor's Riddle
- [随机化调整] Ural 1144 The Emperor's Riddle
- URAL 1994 The Emperor's plan 概率dp
- URAL 1994 The Emperor's plan(dp、期望)
- URAL 1994 The Emperor's plan 求组合数 大数用log+exp处理
- Einstein's Riddle
- GYM 100285 E. The Emperor’s plan(组合数学+dp)
- Ural 1428. Jedi Riddle 二分求幂
- riddle
- Ural 1456. Jedi Riddle 2 整数的阶
- URAL 1518 Jedi Riddle 3 矩阵快速幂
- CF 855A. Tom Riddle's Diary【water】
- Ivan's Car URAL
- stupid emperor
- Ural 1017 The Staircases
- ural 1017. The Staircases
- Ural 1671. Anansi's Cobweb
- Ural 1723. Sandro's Book
- new与malloc的10点区别
- OpenCV中GPU模块的使用
- android-利用broadcast双程序相互监控保证目标程序运行
- android基础——Build.VERSION.SDK_INT
- 如何下载各版本Chrome的离线安装包
- ural 1144. The Emperor's Riddle
- 深度学习(一)
- #storm error(一)
- wamp的phpMyAdmin打不开
- POJ3687 Labeling Balls 特殊拓扑排序
- C++string与int之间的相互转换
- codeforce 630N Forecast
- Spring 4.2.4.RELEASE MVC 学习笔记 - 9 - MedaiType(咋个办呢 zgbn)
- 最简单的Windows程序设计