0

0

Java教程:实现数字序列过滤与指定长度输出

花韻仙語

花韻仙語

发布时间:2025-11-03 15:57:01

|

150人浏览过

|

来源于php中文网

原创

Java教程:实现数字序列过滤与指定长度输出

本教程旨在指导开发者如何使用java编程语言,根据用户输入的指定数量`n`,生成一个从1开始的数字序列。该序列将严格排除所有包含数字'1'的整数,并确保最终输出的数字个数恰好为`n`。文章将介绍两种核心实现方法:基于字符串转换的简洁方案和基于数学运算的效率方案,并提供详细代码示例与逻辑解析。

需求分析与问题概述

在编程实践中,我们常会遇到需要对数字序列进行筛选和处理的场景。本教程聚焦于一个具体问题:用户输入一个整数 n,程序需要从1开始递增查找数字,如果某个数字中包含数字'1'(例如1, 10, 121等),则跳过该数字;否则,将其添加到输出序列中。这个过程一直持续,直到输出序列中包含了 n 个符合条件的数字为止。最终输出的数字数量必须与用户输入的 n 值严格匹配。

例如,如果用户输入 22,程序应输出一个包含22个数字的序列,这些数字都不含'1',且按升序排列。输出可能为:2, 3, 4, 5, 6, 7, 8, 9, 20, 22, 23, 24, 25, 26, 27, 28, 29, 30, 32, 33, 34, 35。

实现方法一:字符串转换法

这种方法的核心思想是将每个待检查的整数转换为字符串,然后利用字符串的 contains() 方法来判断其中是否包含字符 '1'。

逻辑步骤

  1. 获取用户输入: 使用 Scanner 类获取用户输入的整数 n。
  2. 初始化计数器: 设置一个计数器 count,用于记录已输出的符合条件的数字数量,初始值为0。
  3. 循环迭代: 使用一个 for 循环,从 i = 1 开始递增,循环条件是 count < n。这意味着循环将一直进行,直到找到 n 个符合条件的数字。
  4. 检查数字: 在循环内部,将当前数字 i 转换为字符串 String.valueOf(i)。
  5. 判断是否包含 '1': 使用 String.valueOf(i).contains("1") 判断字符串中是否含有 '1'。
  6. 跳过或输出:
    • 如果包含 '1',则使用 continue 语句跳过当前循环的剩余部分,直接进入下一次迭代。
    • 如果不包含 '1',则打印数字 i,并将 count 增加1。
  7. 关闭资源: 程序结束时关闭 Scanner 对象。

示例代码

import java.util.Scanner;

public class NumberFilterString {
    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        System.out.println("请输入一个整数n:");
        int num = sc.nextInt(); // 获取用户输入的n

        int count = 0; // 初始化已输出数字的计数器
        System.out.println("符合条件的数字序列如下:");

        // 循环查找并输出n个符合条件的数字
        for (int i = 1; count < num; i++) {
            // 将当前数字转换为字符串
            if (String.valueOf(i).contains("1")) {
                continue; // 如果字符串中包含'1',则跳过当前数字
            }
            System.out.print(i + " "); // 输出符合条件的数字
            count++; // 计数器加1
        }
        System.out.println("\n总共输出了 " + count + " 个数字。");
        sc.close(); // 关闭Scanner
    }
}

优缺点

  • 优点: 代码简洁易懂,利用Java内置的字符串处理功能,实现直观。
  • 缺点: 每次迭代都需要进行整数到字符串的转换,这在处理大量数字时可能会带来一定的性能开销。

实现方法二:数学运算法

为了避免字符串转换带来的性能损耗,我们可以采用纯数学运算的方式来检查一个数字是否包含 '1'。这种方法通过反复取模和除法来检查数字的每一位。

PaperFake
PaperFake

AI写论文

下载

立即学习Java免费学习笔记(深入)”;

逻辑步骤

  1. 获取用户输入和初始化计数器: 与方法一相同。
  2. 循环迭代: 与方法一相同。
  3. 检查数字(数学方式): 在循环内部,对于当前数字 i,创建一个临时变量 val = i。
    • 使用一个 while 循环,只要 val > 0 就继续。
    • 在 while 循环内部,通过 val % 10 获取 val 的个位数。
    • 如果个位数是 '1',则设置一个布尔标志 hasOne = true,并立即 break 跳出内部 while 循环,因为已经确定该数字包含 '1'。
    • 否则,通过 val = val / 10 去掉个位数,继续检查下一位。
  4. 跳过或输出:
    • 如果 hasOne 为 true,则使用 continue 语句跳过当前外部 for 循环的剩余部分。
    • 如果 hasOne 为 false(表示数字不含 '1'),则打印数字 i,并将 count 增加1。
  5. 关闭资源: 程序结束时关闭 Scanner 对象。

示例代码

import java.util.Scanner;

public class NumberFilterMath {
    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        System.out.println("请输入一个整数n:");
        int num = sc.nextInt(); // 获取用户输入的n

        int count = 0; // 初始化已输出数字的计数器
        System.out.println("符合条件的数字序列如下:");

        // 循环查找并输出n个符合条件的数字
        for (int i = 1; count < num; i++) {
            int val = i; // 使用临时变量进行数字位检查
            boolean hasOne = false; // 标志位,指示是否包含数字'1'

            // 循环检查数字的每一位
            while (val > 0) {
                if (val % 10 == 1) { // 如果当前位是'1'
                    hasOne = true; // 设置标志
                    break;         // 找到'1'后即可停止检查
                }
                val = val / 10; // 移除当前位,检查下一位
            }

            if (hasOne) {
                continue; // 如果包含'1',则跳过当前数字
            }
            System.out.print(i + " "); // 输出符合条件的数字
            count++; // 计数器加1
        }
        System.out.println("\n总共输出了 " + count + " 个数字。");
        sc.close(); // 关闭Scanner
    }
}

优缺点

  • 优点: 避免了字符串转换的开销,对于处理非常大的数字或需要高性能的场景可能更有效率。
  • 缺点: 逻辑上比字符串转换略显复杂,需要一个内部 while 循环来处理每一位。

注意事项与总结

  1. 循环条件: 两种方法都使用了 for (int i = 1; count < num; i++) 这样的循环结构。i 是当前检查的数字,从1开始递增;count 是已输出的符合条件的数字数量。循环的关键在于 count < num,它确保了程序会一直运行直到输出 num 个符合条件的数字。
  2. continue 关键字: continue 语句在此处发挥了重要作用,它允许程序在发现不符合条件的数字时,跳过当前循环的剩余代码,直接进入下一次迭代,从而避免了不必要的处理。
  3. 输入与输出: 确保程序能够正确接收用户输入,并以清晰的格式输出结果。在实际应用中,可以考虑将输出的数字存储到列表中,而不是直接打印,以便后续处理。
  4. 资源管理: 使用 Scanner 对象后,务必调用 sc.close() 关闭资源,以防止资源泄露。

综上所述,根据具体需求,开发者可以选择适合的实现方法。如果追求代码的简洁性和可读性,且对性能要求不是极致,字符串转换法是一个不错的选择。如果需要处理大量数据,对性能有较高要求,那么数学运算法会是更优的方案。理解这两种方法的核心逻辑,有助于在不同场景下灵活应对类似的问题。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

1051

2023.08.02

counta和count的区别
counta和count的区别

Count函数用于计算指定范围内数字的个数,而CountA函数用于计算指定范围内非空单元格的个数。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

203

2023.11.20

while的用法
while的用法

while的用法是“while 条件: 代码块”,条件是一个表达式,当条件为真时,执行代码块,然后再次判断条件是否为真,如果为真则继续执行代码块,直到条件为假为止。本专题为大家提供while相关的文章、下载、课程内容,供大家免费下载体验。

107

2023.09.25

java中break的作用
java中break的作用

本专题整合了java中break的用法教程,阅读专题下面的文章了解更多详细内容。

120

2025.10.15

java break和continue
java break和continue

本专题整合了java break和continue的区别相关内容,阅读专题下面的文章了解更多详细内容。

261

2025.10.24

java break和continue
java break和continue

本专题整合了java break和continue的区别相关内容,阅读专题下面的文章了解更多详细内容。

261

2025.10.24

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

761

2023.08.03

js截取字符串的方法
js截取字符串的方法

js截取字符串的方法有substring()方法、substr()方法、slice()方法、split()方法和slice()方法。本专题为大家提供字符串相关的文章、下载、课程内容,供大家免费下载体验。

221

2023.09.04

TypeScript类型系统进阶与大型前端项目实践
TypeScript类型系统进阶与大型前端项目实践

本专题围绕 TypeScript 在大型前端项目中的应用展开,深入讲解类型系统设计与工程化开发方法。内容包括泛型与高级类型、类型推断机制、声明文件编写、模块化结构设计以及代码规范管理。通过真实项目案例分析,帮助开发者构建类型安全、结构清晰、易维护的前端工程体系,提高团队协作效率与代码质量。

26

2026.03.13

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Kotlin 教程
Kotlin 教程

共23课时 | 4.4万人学习

C# 教程
C# 教程

共94课时 | 11.3万人学习

Java 教程
Java 教程

共578课时 | 81.8万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号