如何用Java实现三位数中偶数位替换为用户指定奇数的程序

本文详解如何编写java程序,接收一个三位数,逐位判断百、十、个位是否为偶数;若是,则提示用户输入一个奇数进行替换,并最终输出修改后的新三位数。

在处理数字各位操作时,常见的误区是逻辑嵌套混乱

(如原代码中使用 else if 串联所有判断),导致仅当高位为偶数时才检查低位,从而跳过本应处理的十位或个位。正确的做法是独立判断每一位——无论前一位是否被替换,都应单独检查并允许用户干预。

以下是修复并优化后的完整可运行代码:

import java.util.Scanner;

public class ReplaceEvenDigits {
    public static void main(String[] args) {
        Scanner ob = new Scanner(System.in);
        System.out.print("请输入一个三位整数(100–999):");
        int n = ob.nextInt();

        if (n < 100 || n > 999) {
            System.out.println("错误:输入不是有效的三位数!");
            return;
        }

        // 分离各位数字
        int hundredsDigit = n / 100;      // 百位
        int tensDigit = (n / 10) % 10;     // 十位
        int onesDigit = n % 10;            // 个位

        // 处理百位(若为偶数)
        if (hundredsDigit % 2 == 0) {
            System.out.print("百位数字 " + hundredsDigit + " 是偶数,请输入一个奇数替换它:");
            int replacement = ob.nextInt();
            if (replacement % 2 == 0) {
                System.out.println("⚠ 提示:输入的是偶数,将保留原数字 " + hundredsDigit);
            } else {
                hundredsDigit = replacement;
            }
        }

        // 处理十位(若为偶数)
        if (tensDigit % 2 == 0) {
            System.out.print("十位数字 " + tensDigit + " 是偶数,请输入一个奇数替换它:");
            int replacement = ob.nextInt();
            if (replacement % 2 == 0) {
                System.out.println("⚠ 提示:输入的是偶数,将保留原数字 " + tensDigit);
            } else {
                tensDigit = replacement;
            }
        }

        // 处理个位(若为偶数)
        if (onesDigit % 2 == 0) {
            System.out.print("个位数字 " + onesDigit + " 是偶数,请输入一个奇数替换它:");
            int replacement = ob.nextInt();
            if (replacement % 2 == 0) {
                System.out.println("⚠ 提示:输入的是偶数,将保留原数字 " + onesDigit);
            } else {
                onesDigit = replacement;
            }
        }

        // 构造并输出结果
        int result = hundredsDigit * 100 + tensDigit * 10 + onesDigit;
        System.out.println("✅ 替换完成!新数字为:" + result);
        ob.close();
    }
}

? 关键改进说明:

  • 扁平化逻辑结构:三个 if 独立判断,确保每位偶数都能被识别和替换(原代码因误用 else if 导致后续位被跳过);
  • 清晰变量命名:hundredsDigit 等替代 h/t/o/z,大幅提升可读性与可维护性;
  • 结果显式输出:末尾统一计算并打印 result,解决“程序无输出即退出”的核心问题;
  • 基础输入校验:对非三位数做前置拦截,避免异常流程;
  • 资源安全关闭:调用 ob.close() 防止资源泄漏。

? 进阶建议(供延伸学习):

  • 将“获取替换数字并校验”封装为 int getOddReplacement(String digitName, int original) 方法,消除重复代码;
  • 使用 while 循环配合 hasNextInt() 实现健壮的输入容错(防止用户输入 "abc" 导致程序崩溃);
  • 扩展支持任意位数:将数字转为字符串遍历,或用循环+取模动态提取各位。

该方案兼顾初学者理解成本与工程实践规范,可直接编译运行,准确达成“输入123 → 检测到2(十位)为偶 → 用户输入7 → 输出173”的预期效果。