L1-058 6翻了(15分)[java][python]

题目ID :L1-058
分数 :15分
语言:Java / Python

题目描述

"666"是一种网络用语,大概是表示某人很厉害、我们很佩服的意思。最近又衍生出另一个数字"9",意思是"6翻了",实在太厉害的意思。本题就请你编写程序,将那些过时的、只会用"666"的人用"9"来替代吧。

输入格式

输入在第一行给出一个长度不超过 10000 的、仅由英文字母构成的非空字符串。

输出格式

在一行中输出替换后的字符串。

输入样例

复制代码
wanwusanguanzhisanbaigaolaosongjiulao

输出样例

复制代码
9wusanguanzhisanbaigaolaosong9lao

解题思路

  1. 遍历字符串中的每个字符
  2. 如果遇到字符 '6',统计连续出现的个数
  3. 如果连续出现3个或更多个'6',用 '9' 替换整个连续的 '6' 串
  4. 否则保持原样输出

关键点:需要处理连续的多个 '6',用 '9' 一次性替换整个连续段。

代码实现

Java

java 复制代码
import java.util.*;

public class Main {
    public static void main(String[] args) {
        Scanner scanner = new Scanner(System.in);
        String s = scanner.nextLine();

        StringBuilder sb = new StringBuilder();
        int i = 0;

        while (i < s.length()) {
            if (s.charAt(i) == '6') {
                int count = 0;
                while (i < s.length() && s.charAt(i) == '6') {
                    count++;
                    i++;
                }
                if (count >= 3) {
                    sb.append('9');
                } else {
                    for (int j = 0; j < count; j++) {
                        sb.append('6');
                    }
                }
            } else {
                sb.append(s.charAt(i));
                i++;
            }
        }

        System.out.println(sb.toString());
    }
}

Python

python 复制代码
s = input()
result = []
i = 0

while i < len(s):
    if s[i] == '6':
        count = 0
        while i < len(s) and s[i] == '6':
            count += 1
            i += 1
        if count >= 3:
            result.append('9')
        else:
            result.append('6' * count)
    else:
        result.append(s[i])
        i += 1

print(''.join(result))

运行验证

样例输入 样例输出 结果
wanwusanguanzhisanbaigaolaosongjiulao 9wusanguanzhisanbaigaolaosong9lao

复杂度分析

  • 时间复杂度:O(n),遍历字符串一次
  • 空间复杂度:O(n),存储结果字符串

总结

本题主要考察字符串的遍历和连续字符的处理。核心算法:

  1. 使用指针遍历字符串
  2. 遇到连续 '6' 时统计个数
  3. 根据连续个数决定输出 '9' 还是原字符
相关推荐
Aurorar0rua4 小时前
CS50 x 2024 Notes C -14
c语言·开发语言·学习方法
小短腿的代码世界5 小时前
从.qrc到rcc编译器:Qt资源系统的隐秘运作机制与大型项目性能突围
开发语言·qt
MY_TEUCK5 小时前
【2026最新Python+AI学习基础】Python 入门笔记篇
笔记·python·学习
2401_833269306 小时前
Java网络编程入门
java·开发语言
金銀銅鐵6 小时前
[Java] 如何将 Lambda 表达式对应的类保存到 class 文件中?
java·后端
青瓦梦滋6 小时前
C++的IO流与STL的空间配置器
开发语言·c++
赢乐6 小时前
大模型学习笔记:检索增强生成(RAG)架构
人工智能·python·深度学习·机器学习·智能体·幻觉·检索增强生成(rag)
五月君_6 小时前
Bun v1.3.14 发布,Rust 版即将进 Claude Code 内测,下一版可能就告别 Zig
开发语言·后端·rust
それども7 小时前
Gradle 构建疑难杂症 Could not find netty-transport-native-epoll-linux-aarch_64.ja
java·服务器·gradle·maven
正儿八经的少年7 小时前
application.yml 系列配置文件作用与区别
java·配置文件