L1-1出生年
以上是新浪微博中一奇葩貼:“我出生於1988年,直到25歲才遇到4個數字都不相同的年份。”也就是說,直到2013年才達到“4個數字都不相同”的要求。本題請你根據要求,自動填充“我出生於y年,直到x歲才遇到n個數字都不相同的年份”這句話。
輸入格式:
輸入在一行中給出出生年份y和目標年份中不同數字的個數n,其中y在[1, 3000]之間,n可以是2、或3、或4。注意不足4位的年份要在前面補零,例如公元1年被認爲是0001年,有2個不同的數字0和1。
輸出格式:
根據輸入,輸出x和能達到要求的年份。數字間以1個空格分隔,行首尾不得有多餘空格。年份要按4位輸出。注意:所謂“n個數字都不相同”是指不同的數字正好是n個。如“2013”被視爲滿足“4位數字都不同”的條件,但不被視爲滿足2位或3位數字不同的條件。
輸入樣例1:1988 4輸出樣例1:
25 2013
輸入樣例2:
1 2輸出樣例2:
0 0001
#include<cstdio>
#include<iostream>
using namespace std;
int main(){
int year,n,first,num[4],all[10];
int sum=0;
cin>>year>>n;
first=year;
while(1){
//年份的各個位數
num[0]=year/1000;
num[1]=year/100%10;
num[2]=year/10%10;
num[3]=year%10;
for(int i=0;i<4;i++)
all[num[i]]++;//這是這道題的關鍵,用all來標記各個數字的出現次數
for(int i=0;i<10;i++){
if(all[i]>=1)
sum++;
}
if(sum==n)
break;
for(int i=0;i<10;i++)
all[i]=0;
sum=0;
year++;
}
printf("%d %04d",year-first,year);//%04d的表示法
}