PTA L1-033 出生年(详解)
前言:本期是关于出生年的详解,内容包括四大模块:题目,代码实现,大致思路,代码解读,今天你c了吗?
前言:本期是关于出生年的详解,内容包括四大模块:题目,代码实现,大致思路,代码解读,今天你c了吗?
题目:

以上是新浪微博中一奇葩贴:“我出生于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<stdio.h>
int differ(int y)
{
int arr[10] = { 0 };
arr[y % 10] = 1;
arr[y / 10 % 10] = 1;
arr[y / 100 % 10] = 1;
arr[y / 1000] = 1;
int i = 0;
int count = 0;
for (i = 0; i < 10; i++)
{
if (arr[i] == 1)
{
count++;
}
}
return count;
}
int main()
{
int y = 0;
int num = 0;
scanf("%d %d", &y, &num);
int add = 0;
while (differ(y) != num)
{
add++;
y++;
}
printf("%d %04d", add, y);
return 0;
}
大致思路:
预备了解:
differ函数:统计组成年的不同数字个数
add:统计需要多少年才能遇到符合条件的年
count:统计不同的数字个数
num:输入的不同数字个数
1. 使用自定义differ函数统计统计组成年的不同数字个数
2. 若是不同的个数不等于输入的不同数字的个数,则add++,y++
代码解读:
函数部分:
int differ(int y)
{
int arr[10] = { 0 };
arr[y % 10] = 1;
arr[y / 10 % 10] = 1;
arr[y / 100 % 10] = 1;
arr[y / 1000] = 1;
int i = 0;
int count = 0;
for (i = 0; i < 10; i++)
{
if (arr[i] == 1)
{
count++;
}
}
return count;
}
1.将年,比如1988的每一位数字作为下标,将其对应的arr数组中的某一空间置1,可以达到去重效果,即1988存到数组中,只有下标为1,9,8的空间内容是1(arr数组一开始就被初始化为全0)
此种方法解决了特殊情况:y=1,num=2
年:1,在differ函数中统计的不同数字个数为2,因为arr[1]的值置成了1,而且arr[0]也置成1
2.遍历arr数组,若是数组中的某块空间的内容为1,则说明年中有此数字 ,不同的个数+1
主体部分:
int y = 0;
int num = 0;
scanf("%d %d", &y, &num);
int add = 0;
while (differ(y) != num)
{
add++;
y++;
}
printf("%d %04d", add, y);
while循环适用于不确定循环次数的情况
若是differ函数返回的不同数字个数 不等于输入的num,则循环继续,将不满足条件的当前的年统计+1即add++,同时找下一个年,y++
更多推荐



所有评论(0)