NOIP2016年普及组模拟考试(9.3) 1.笨笨玩游戏
2016-09-06 13:50
281 查看
一、原题
1.笨笨玩游戏(game.cpp)
【题目描述】
一天,笨笨和妈妈玩游戏,妈妈 给笨笨出N个正整数,让笨笨把这N个正整数连接生成一个“大”的整数,每个正整数只使用一次,让笨笨告诉妈妈这样生成的大整数的最大值。
例如,给出4个整数:123, 124, 56, 90,可以连接生成的大整数有:1231245690, 1241235690, 5612312490, 9012312456, 9056124123等等,对本例,总共可以生成24个大整数。而其实最大整数是:9056124123
【输入】
第1行:1 个整数N(1<=N<=50)
第2行:N个整数,每个整数不超过INT_MAX。
【输出】
第1行:生成的最大整数。
【样例输入】
4 123 124 56 90
【样例输出】
9056124123
二、分析
这道题首先需要贪心,然后把N个整数按照字符串的形式比较方式,从大到小进行排序,并按照排序后的顺序依次输出,这样能保证生成的大整数一定是最大的。还有一个方法,转换成字符,连成字符串,比较各个字符串的大小,即可找出最优解。三、源程序
#include<cstdio> #include<cstring> #include<algorithm> using namespace std; int a[53],n,i; char s[1000],p[20]; bool check(int a,int b)//排序 { char x[20],y[20],q[20],w[20]; sprintf(x,"%d",a);//转化成字符串 sprintf(y,"%d",b);//转化成字符串 strcpy(q,x);//复制 strcpy(w,y);//复制 strcat(q,y);//连接字符 strcat(w,x);//连接字符 if(strcmp(q,w)<0) return 1; return 0; } int main() { freopen("game.in","r",stdin);//文件输入输出 freopen("game.out","w",stdout); scanf("%d",&n); for(i=0;i<n;i++)//读入 scanf("%d",&a[i]); sort(a,a+n,check);//排序 for(i=n-1;i>=0;i--) { memset(p,0,sizeof(p));//清零 sprintf(p,"%d",a[i]);//转化成int数组 strcat(s,p);//连接 } puts(s);//输出 }
相关文章推荐
- 【NOIP普及组】2016年模拟考试(9.3)——笨笨玩游戏
- NOIP2016年普及组模拟考试(9.3) 2.笨笨的西瓜种植
- 【NOIP普及组】【DFS】2016年模拟考试(9.3)——母亲的牛奶
- 【NOIP普及组】2016年模拟考试(9.3)——部落卫队
- 【NOIP普及组】2016年模拟考试(9.3)——笨笨的西瓜种植
- NOIP2016年普及组模拟考试(9.3) 4.部落卫队
- NOIP2016年普及组模拟考试(9.3) 3.笨笨连线游戏
- NOIP2016年普及组模拟考试(9.3) 5.母亲的牛奶
- 【NOIP普及组】2016年模拟考试(11.5)——火柴棒等式
- 【NOIP普及组】2016模拟考试(10.29)——摆花
- 【NOIP普及组】2016模拟考试(11.1)——生活大爆炸版石头剪刀布
- 【NOIP普及组】2016模拟考试(10.29)——海港的船只
- 【NOIP普及组】2016模拟考试(11.8)——公路
- 【NOIP普及组】2016模拟考试(10.29)——排座椅
- 【NOIP2011模拟9.3】作弊的发牌者 (Standard IO)
- 【NOIP2011模拟9.3】旅行 (Standard IO)
- noip1996 乘法运算 - 普及组 (模拟)
- 2016.08.18【初中部 NOIP普及组 】模拟赛
- NOIP2010-普及组复赛模拟试题-第二题-数字积木
- jzoj 【2014.8.17NOIP普及组模拟】公牛数学