话说这次月赛好多水题。这道题其实就是个9进制,,也没什么意思。比赛的时候没有看见0,wa了一次,检查了好久,搞的我都不敢提交了,后来才发现数据还有0,,,题目:
不吉利的数字
- 描述
-
一些普通的数字在很多人眼里是不吉利。如数字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
#include <iostream> #include <cstdio> using namespace std; int sum; int mi(int x,int y){ int s=1; for(int i=0;i<y;++i){ s*=9; } return x*s; } bool fun(int x){ sum=0; int k=0; while(x){ int y=x%10; x/=10; if(!y) return false; sum+=mi(y,k++); } return true; } int main(){ int n; while(~scanf("%d",&n)){ if(n==0){puts("Unlucky");continue;} bool flag=fun(n); if(flag==false) puts("Unlucky"); else{ printf("%d\n",sum); } } return 0; }