L1-033 出生年(java)

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

2. 思路

计算年份中含有的不同数字的个数很简单, 就是要注意不足4位的年份要在前面补0, 所以我在计算年份中不同数字的方法中先判断是不是不足4位的年份, 是的话,就先在list中添加一个0, 然后再去计算年份中不同的数字
最后输出用的是printf, %04d表示输出整数占四位,不足四位的用0补齐😄

3. 代码示例

import java.io.*;
import java.util.ArrayList;

public class 出生年 {
    //计算年份中数字的个数
    public static int count(int y){
        //存储年份中不同的数字
        ArrayList<Integer> list = new ArrayList<>();
        //不足4位的年份,因为要在前面补0, 所以如果年份中没有0要添加0到list中
        if(y < 1000){
            list.add(0);
        }
        while (y > 0){
            int num = y % 10;
            if(!list.contains(num)){
                list.add(num);
            }
            y /= 10;
        }
        return list.size();
    }
    public static void main(String[] args) throws IOException {
        BufferedReader bf = new BufferedReader(new InputStreamReader(System.in));
        String[] line = bf.readLine().split(" ");
        int y = Integer.parseInt(line[0]);
        int n = Integer.parseInt(line[1]);
        //x : 直到x岁,才能遇见n个数字都不同的年份
        int x = 0;
        while (n != count(y)){
            y++;
            x++;
        }

        System.out.printf("%d %04d", x, y);
    }
}

在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Lilianac

你的鼓励是我的动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值