【蓝桥杯训练题】奇怪的数列

题目描述

从 X 星截获一份电码,是一些数字,如下:

13

1113

3113132113

1113122113

YY 博士经彻夜研究,发现了规律:

第一行的数字随便是什么,以后每一行都是对上一行"读出来"

比如第 2 行,是对第 1 行的描述,意思是:1 个 1,1 个 3,所以是:1113

第 3 行,意思是:3 个 1,1 个 3,所以是:3113

请你编写一个程序,可以从初始数字开始,连续进行这样的变换。

输入描述
第一行输入一个数字组成的串,不超过 100 位。

第二行,一个数字 n,表示需要你连续变换多少次, n 不超过 20。

输出描述
输出一个串,表示最后一次变换完的结果。

输入输出样例

示例

输入

5
7

输出

13211321322115

解题思路

创建循环,在循环里:将数字改成字符串,通过遍历str.chatAt(i)并比较与前一个字符是否相同,用count计次,来达到算字符串相同字符的目的。通过StringBuffer作为结果的承接,并作为下一次循环的目的字符串。

代码1


import java.util.Scanner;

public class Main {
    //1 <= num <= 3999
    public void LookAndSay(int originNum,int times) {
        StringBuffer sb = new StringBuffer();
        String numToStr = Integer.toString(originNum);
        String temp = numToStr;


        for(int i = 0;i<times;i++) {
        
            int count = 1;
            //单独考虑第一位的数字
           if(temp.charAt(0)!=temp.charAt(1)) {
               sb.append(count).append(temp.charAt(0));
              }
            for (int j = 1; j < temp.length(); j++) {
                if (temp.charAt(j) == temp.charAt(j - 1)) {
                    count++;
                }else {
                    //处理前面相同的元素
                    sb.append(count).append(temp.charAt(j - 1));
                    temp = sb.toString();
                    System.out.println(temp);

                    count = 1;
                    sb.append(count).append(temp.charAt(j));
                    //更新temp
                    temp = sb.toString();
                    System.out.println(temp);
                }
            } sb.setLength(0);
        }
    }

    public static void main(String[] args) {
        Main main = new Main();
        Scanner sc = new Scanner(System.in);
        System.out.println("Original Number:");
        int originNum = sc.nextInt();
        System.out.println("Times:");
        int times = sc.nextInt();
        main.LookAndSay(originNum,times);
    }
}

输入

Original Number:
12
Times:
2

输出

1111
111111

分析

我们发现两次循环均出错。
对于第一次循环,第一位是正确的;当j=1时,多考虑了一遍j=0时的情况,并且打印的也很混乱。
简单的修改一下。

代码2


import java.util.Scanner;

public class LookandSay{

    // 1 <= num <= 3999
    public void LookAndSay(int originNum, int times) {
        StringBuilder sb = new StringBuilder();
        String temp = Integer.toString(originNum);

        for (int i = 0; i < times; i++) {
            int count = 1;

            for (int j = 1; j < temp.length(); j++) {
                if (temp.charAt(j) == temp.charAt(j - 1)) {
                    count++;
                } else {
                    // 处理前面相同的元素
                    sb.append(count).append(temp.charAt(j - 1));
                    count = 1;
                }
            }

            // 处理最后一个数字
            sb.append(count).append(temp.charAt(temp.length() - 1));

            // 更新temp
            temp = sb.toString();
            System.out.println(temp);

            // 重置sb
            sb.setLength(0);
        }
    }

    public static void main(String[] args) {
        LookandSay lookandsay = new LookandSay();
        Scanner sc = new Scanner(System.in);
        System.out.println("Original Number:");
        int originNum = sc.nextInt();
        System.out.println("Times:");
        int times = sc.nextInt();
        lookandsay.LookAndSay(originNum, times);
    }
}

Finished.

--------------------蓝桥杯备赛系列正在不断更新中,欢迎各位大佬指导----------------------------------------------

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值