
本教程旨在指导如何在java中生成一个特定长度的整数序列,该序列中的每个数字都不能包含数字'1'。文章将介绍两种实现方法:一种利用字符串转换进行判断,另一种则通过纯数学运算逐位检查,并详细讲解其逻辑、代码实现及适用场景,确保输出序列的长度与用户输入严格匹配。
在日常编程中,我们有时会遇到需要根据特定规则过滤或生成数字序列的需求。本教程将聚焦一个具体问题:给定一个正整数 N,要求程序从1开始,依次查找并打印前 N 个不包含数字'1'的整数。这意味着如果一个数字(例如1、10、121等)的任何位上出现了数字'1',它就应该被跳过。最终打印出的数字总数必须精确地等于用户输入的 N。例如,如果用户输入 N=22,程序应输出22个不含数字'1'的整数,如2, 3, ..., 9, 20, 22, ..., 35等。
解决此问题的核心在于两个方面:
整体算法流程如下:
接下来,我们将探讨两种实现“判断数字是否包含'1'”的方法。
立即学习“Java免费学习笔记(深入)”;
这种方法将整数转换为字符串,然后利用字符串的 contains() 方法来检查是否存在字符'1'。这种方式直观且易于理解。
将一个整数 i 转换为其字符串表示形式 String.valueOf(i),然后调用 String 对象的 contains("1") 方法。如果返回 true,则表示该数字包含'1';否则,不包含。
import java.util.Scanner;
public class ExcludeOneNumbersString {
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
System.out.println("请输入一个整数N,程序将打印N个不含数字'1'的整数:");
int num = sc.nextInt(); // 获取用户输入的N
int foundCount = 0; // 已找到并打印的数字数量
for (int currentNum = 1; foundCount < num; currentNum++) {
// 将当前数字转换为字符串,并检查是否包含字符'1'
if (String.valueOf(currentNum).contains("1")) {
continue; // 如果包含'1',则跳过当前数字,继续下一个
}
// 如果不包含'1',则打印该数字并增加计数
System.out.print(currentNum + " ");
foundCount++;
}
System.out.println("\n共打印了 " + foundCount + " 个数字。");
sc.close(); // 关闭Scanner资源
}
}为了避免字符串转换带来的性能开损,我们可以采用纯数学运算的方式来检查数字的每一位。
对于一个整数 val,我们可以通过循环执行以下操作来逐位检查:
import java.util.Scanner;
public class ExcludeOneNumbersMath {
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
System.out.println("请输入一个整数N,程序将打印N个不含数字'1'的整数:");
int num = sc.nextInt(); // 获取用户输入的N
int foundCount = 0; // 已找到并打印的数字数量
for (int currentNum = 1; foundCount < num; currentNum++) {
int tempVal = currentNum;
boolean hasOne = false; // 标记当前数字是否包含'1'
// 逐位检查数字
while (tempVal > 0) {
if (tempVal % 10 == 1) { // 如果个位是1
hasOne = true; // 设置标记
break; // 找到'1'后即可停止检查
}
tempVal = tempVal / 10; // 移除个位,检查下一位
}
if (hasOne) {
continue; // 如果包含'1',则跳过当前数字
}
// 如果不包含'1',则打印该数字并增加计数
System.out.print(currentNum + " ");
foundCount++;
}
System.out.println("\n共打印了 " + foundCount + " 个数字。");
sc.close(); // 关闭Scanner资源
}
}以用户输入 N=22 为例,两种方法都将产生如下(或类似格式)的输出:
请输入一个整数N,程序将打印N个不含数字'1'的整数: 22 2 3 4 5 6 7 8 9 20 22 23 24 25 26 27 28 29 30 32 33 34 35 共打印了 22 个数字。
可以看到,程序成功地从1开始查找,跳过了1、10、11、12...19、21等包含数字'1'的数字,最终打印了22个不含'1'的整数,且总数与用户输入匹配。
本教程详细介绍了如何在Java中实现一个功能:生成指定数量且不含特定数字(本例中为'1')的整数序列。我们探讨了两种主要的实现策略:
在实际开发中,选择哪种方法取决于具体的性能需求和代码可读性偏好。理解这两种方法不仅能解决当前问题,也为将来处理类似数字过滤和序列生成问题提供了通用的思路。核心在于对循环控制、条件判断以及数字处理逻辑的灵活运用。
以上就是Java编程教程:生成指定数量且不含数字‘1’的整数序列的详细内容,更多请关注php中文网其它相关文章!
编程怎么学习?编程怎么入门?编程在哪学?编程怎么学才快?不用担心,这里为大家提供了编程速学教程(入门课程),有需要的小伙伴保存下载就能学习啦!
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号