原题链接:题目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); 
	}
}


点赞(1)
 

0.0分

0 人评分

C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:

一点编程也不会写的:零基础C语言学练课程

解决困扰你多年的C语言疑难杂症特性的C语言进阶课程

从零到写出一个爬虫的Python编程课程

只会语法写不出代码?手把手带你写100个编程真题的编程百练课程

信息学奥赛或C++选手的 必学C++课程

蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程

手把手讲解近五年真题的蓝桥杯辅导课程

评论列表 共有 0 条评论

暂无评论