当前位置: 首页 > article >正文

PTA 一维数组7-3出生年(本题请你根据要求,自动填充“我出生于y年,直到x岁才遇到n个数字都不相同的年份”这句话)

以上是新浪微博中一奇葩贴:“我出生于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


解题 

//题目要求:我出生于y年,直到x岁才遇到n个数字都不相同的年份;也就是说,直到2013年才达到4个数字都不相同
//输入为出生年份y,不相同数字n;
//输出为年龄x岁,目标年份i;
#include <stdio.h>
#include <string.h>
int main() {
    int bir[4]; //最多4个不相同数字,因此开一个空间存放不同数字的次数。
    int y, n;  
    scanf("%d%d", &y, &n); //出生年份,不相同数字n
    int i, count = 0;
    for (i = y; i < 3020; i++) {//输入为出生年份,作为界限的目标年份未知,取i<3020(ID为“代码晓菜鸡”的大佬经过检测上界限为3012)       
        count = 1;
        bir[0] = i / 1000;
        bir[1] = i / 100 % 10;
        bir[2] = i / 10 % 10;
        bir[3] = i % 10;
        if (bir[0] != bir[1] && bir[0] != bir[2] && bir[0] != bir[3])
            count++; //检查千位数字是否与其他位上的数字不同,如果是,增加计数器。
        if (bir[1] != bir[2] && bir[1] != bir[3]) 
            count++; //检查百位数字是否与其他位上的数字不同,如果是,增加计数器。
        if (bir[2] != bir[3]) count++; //检验个位
        if (count == n) break;
    }
    printf("%d %04d", i - y, i); //年龄,目标年份
    return 0;
}

注意

count等于n时,意味着已经找到了满足条件的年份,此时不需要继续循环,因此使用break语句跳出循环。

这个条件检查是为了确保只打印出第一个满足条件的年份,而不是继续循环并打印出所有满足条件的年份。通过跳出循环,程序可以避免对后续年份的检查,从而提高程序的效率。

正如ID为“代码晓垃圾”的大佬说,这道题直接暴力对比输入年份的每一项异同即可。

本题精髓也就在此了。希望能帮到更多人理清思路吧,到此一维数组就告一段落了。

 


http://www.kler.cn/a/157441.html

相关文章:

  • 用人话讲计算机:Python篇!(十五)迭代器、生成器、装饰器
  • SKETCHPAD——允许语言模型生成中间草图,在几何、函数、图算法和游戏策略等所有数学任务中持续提高基础模型的性能
  • MacOS安装MySQL
  • GhostRace: Exploiting and Mitigating Speculative Race Conditions-记录
  • VUE3+django接口自动化部署平台部署说明文档(使用说明,需要私信)
  • Leetcode Hot 100 【二叉树】104. 二叉树的最大深度
  • C++算法入门练习——最大连续子序列和
  • vue2+electron桌面端一体机应用
  • golang实现函数yamlToStruct(infile,outFile)
  • 如何拆解Unity 2022.3版本的AssetBundle
  • GB/T 29734.1-2013 铝木复合门窗检测
  • 基于SSM的老年公寓信息管理的设计与实现
  • python提取通话记录中的时间信息
  • 翻译: 生成式人工智能的工作原理How Generative AI works
  • 如何使用Cloudreve搭建本地云盘系统并实现随时远程访问
  • VSCode搭建STM32开发环境
  • LLM之Agent(三):HuggingGPT根据用户需求自动调用Huggingface合适的模型
  • 数据库系统概论期末经典大题讲解(用关系代数进行查询)
  • 前端 --- HTML
  • 【设计模式-4.3】行为型——责任链模式
  • Hive安装与配置
  • webpack打包体积优化,减少白屏时间
  • ARM与大模型,狭路相逢
  • 探索人工智能领域——每日20个名词详解【day6】
  • 关于近期互联网行业收缩的一些看法
  • 关于rocketMQ踩坑的那些事