蓝桥杯---奇怪的数列

题目描述

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

13

1113

3113

132113

1113122113

....

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

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

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

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

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

输入描述

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

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

输出描述

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

输入输出样例

用户输出:

5

7

则程序应该输出:

13211321322115

复制代码
import java.util.Scanner;

public class 奇怪的数列 {
    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        String s = sc.nextLine();
        int n = Integer.parseInt(sc.nextLine());
        for (int i=0;i<n;i++) s = f(s);
        System.out.println(s);

    }
    public  static String f(String x){
        String y="";
        char t = x.charAt(0);//t:用于存储字符串 x 的第一个字符。
        int n = 1;
        for (int i=1;i<x.length();i++){
            char c = x.charAt(i);
            if(c==t) n++;
            else {
                y+=n;//空字符串可以直接写东西进去
                y+=t;
                t=c;
                n=1;
            }
        }
        y+=n;
        y+=t;
        return y;
    }
}

问题

(1) 如何获取字符串的第一个字符,并且可以循环依次往下获取

第一种:把字符串变为数组

复制代码
int a[] = new int[str.length()];
for (int i=0;i<str.length();i++){
    a[i] = Integer.parseInt(str.substring(i,i+1));
    //str.substring(i,i+1)==获取字符串的第一个字符,并且可以循环依次往下获取
}

第二种:直接取出字符串,拿出第一个字符,依次比较

注:(1)一个空字符串可以直接写进东西;y+=n

(2)提取字符串第几个字符用 chatAt(i)

相关推荐
JNU freshman16 分钟前
算法 之 拓 扑 排 序
数据结构·算法
NAGNIP31 分钟前
DeepSeek-R1 架构解析:如何通过强化学习激发大模型的推理能力?
算法
L2ncE40 分钟前
高并发场景数据与一致性的简单思考
java·后端·架构
武昌库里写JAVA41 分钟前
使用 Java 开发 Android 应用:Kotlin 与 Java 的混合编程
java·vue.js·spring boot·sql·学习
小指纹42 分钟前
河南萌新联赛2025第(六)场:郑州大学
java·开发语言·数据结构·c++·算法
叶~璃44 分钟前
云计算:企业数字化转型的核心引擎
java
爱coding的橙子1 小时前
每日算法刷题Day63:8.19:leetcode 堆6道题,用时1h50min
算法·leetcode·职场和发展
码luffyliu1 小时前
MySQL:MVCC机制及其在Java秋招中的高频考点
java·数据库·mysql·事务·并发·mvcc
程序员鱼皮1 小时前
这套 Java 监控系统太香了!我连夜给项目加上了
java·前端·ai·程序员·开发·软件开发
岁忧1 小时前
(nice!!!)(LeetCode 每日一题) 1277. 统计全为 1 的正方形子矩阵 (动态规划)
java·c++·算法·leetcode·矩阵·go·动态规划