前言:本期是关于出生年的详解,内容包括四大模块:题目,代码实现,大致思路,代码解读,今天你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++

Logo

有“AI”的1024 = 2048,欢迎大家加入2048 AI社区

更多推荐