原题链接:题目532 - ACM在线评测系统
描述:
一些普通的数字在很多人眼里是不吉利。如数字4,谐音“死”,所以很多地方都没有带4的数字:比如新校区澡堂衣柜编号及没有4;再如数字13,在西方人眼中代表着坏运气,也是不吉利的数字,13不出远门,楼层不设第13层等等。
假如某些人认为0是不吉利的数字,并且在他们以后的生活中,记录数据都在不在使用含有0的自然数。
他们记录数的序列是1,2,3,4,5,6,7,8,9,11,12,13,14,15,16,17,18,19,21,22.......n,由于不使用数字0,他们记录的数和我们实际使用的自然数有一定的差别,如他们的11,实际就是第10个数,21就是第19个数,以此类推。。。
现在给你一个数n,请判断在不不含0的序列中的,如果在,求n是第几个数,不在,输出Unlucky。
Hint: 105,10523等等,都是含有0的
输入:
有多组测试数据<5000
每组数据占一行,每行有一个数n(0<=n<=1000000)。
以EOF结尾
输出:
每组输出占一行,如果n在不含0的序列中,输出是第几个。如果不在不含0的序列中,输出Unlucky;
样例输入:
11
9
21
10
样例输出:
10
9
19
Unlucky
解题思路:洗澡问题的改良版,如果认为0是不吉利的,从序列的末位到首位,从数字的高位来看,每低位都可取为1到9中的任一数。
注意事项:哪怕用空间换效率,不要超时。如果认为4是不吉利的,数字序列首位不能为0或4可取8数,后续每位可取9数。
参考代码:
#include<stdio.h>
#define max 1000000
int a[max+1];
int main(){
int cmp(int);
int i,N;
for(i=1;i<=max;i++){
if(cmp(i)) a[i]=a[i-1];//若某位有0,以它为下标访问数组,编号与数组中前一个编号相同
else a[i]=a[i-1]+1;//编号加1
}
while(~scanf("%d",&N)){
if(a[N]==a[N-1]) printf("Unlucky\n");//有0是不吉利的
else printf("%d\n",a[N]);
}
return 0;
}
int cmp(int n){
while(n){
if(0==n%10)//某位有0
return 1;
n/=10;//更高位
}
return 0;
}AC后,查找最优代码如下:
#include<stdio.h>
#include<string.h>
int main(){
char a[8];
while(scanf("%s",a)!=EOF){
int i,sum=0,m=1;
int len=strlen(a);
for(i=len-1;i>=0;i--){
if(a[i]=='0'){
printf("Unlucky\n");
sum=0;
break;
}
sum+=(a[i]-'0')*m;
m*=9;//每位都可取为1到9中的任一数
}
if(sum) printf("%d\n",sum);
}
}0.0分
0 人评分
C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:
一点编程也不会写的:零基础C语言学练课程
解决困扰你多年的C语言疑难杂症特性的C语言进阶课程
从零到写出一个爬虫的Python编程课程
只会语法写不出代码?手把手带你写100个编程真题的编程百练课程
信息学奥赛或C++选手的 必学C++课程
蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程
手把手讲解近五年真题的蓝桥杯辅导课程
发表评论 取消回复