Java实现回文数四种方法

简介: Java实现回文数四种方法

干货分享 | 打印回文数的四种方法!!

本文提供了四种方法来打印回文数,大家可以根据题目的要求(如:时间复杂度、运行时间、内存等限制条件)来选取合适的方法。如果题目要求打印的回文数较大,我们可以选择将数字转换为字符串的形式,这样就避免了数字过大而溢出;当然,打印的回文数没有超出Java可以表示的范围,下列的四种方法都可以实现。

下面以打印四位的回文数来举例。

方法一:


直接循环一个四位数的每一位,然后判断是否满足回文数要求。(注:要输出几位的回文数就需要几重循环)

public class Main {
  public void Palindrome() {
    for (int i = 1; i < 10; i++) {
      for (int j = 0; j < 10; j++) {
        for (int x = 0; x < 10; x++) {
          for (int y = 0; y < 10; y++) {
            if (i == y && j == x) {
              System.out.println("" + i + j + x + y);
            }
          }
        }
      }
    }
  }
  public static void main(String[] args) {
    new Main().Palindrome();
  }

方法二:

先将原数字转换成字符串,再逆转字符串,最后判断逆转前后的字符串是否相等。

public class Main {
  public void Palindrome() {
    for(int i  = 1000;i < 10000;i++) {
      String ans = i + "";  //数字转换为字符串
      String reverse = new StringBuffer(ans).reverse().toString();//逆转字符串
      if(ans.equalsIgnoreCase(reverse)) {   //比较两个字符串是否相等
        System.out.println(ans);
      }
    }
  }
  public static void main(String[] args) {
    new Main().Palindrome();
  }
}

方法三:

先将原数字逆转,然后判断逆转前后的数字是否相等。

public class Main {
  public void Palindrome() {
    for(int i  = 1000;i < 10000;i++) {
      int temp = i;
      int reverse = 0;
      while(temp != 0) {
        int remain = temp % 10;
        temp /= 10;
        reverse = reverse * 10 + remain;
      }
      if(reverse == i) {  
        System.out.println(reverse);
      }
    }
  }
  public static void main(String[] args) {
    new Main().Palindrome();
  }

方法四:

将一个四位数的每一位存放在一个数组中,再依次取数组的两端元素并判断是否相等。

public class Main {
  public void Palindrome() {
    for(int i  = 1000;i < 10000;i++) {
      String temp = i + "";
      char[] str = temp.toCharArray();//将字符串以单个字符存放在数组中
      if(str[0] == str[3] && str[1] == str[2]) {
        for(int j = 0;j < str.length;j++) {
          System.out.print(str[j]);
        }
        System.out.println();
      }
    }
  }
  public static void main(String[] args) {
    new Main().Palindrome();
  }
}

补充:如需要降低循环的次数,进行如下判断

1、数字是否为负数

2、数字是否以0结尾

相关文章
|
1天前
|
Java Spring
面对Spring 不支持java8的改变方法
面对Spring 不支持java8的改变方法
|
2天前
|
设计模式 Java 测试技术
Java一分钟之-PowerMock:静态方法与私有方法测试
【6月更文挑战第4天】PowerMock是扩展Mockito的框架,用于模拟静态方法、构造函数和私有方法,以增强Java单元测试的隔离性和覆盖率。核心应用场景包括静态方法模拟、私有方法测试和Final类模拟。常见问题包括配置复杂、过度使用和忽略模拟的真实行为。解决方案包括遵循官方文档、谨慎使用PowerMock、精确控制模拟逻辑和遵循最佳实践。示例展示了如何模拟静态方法,通过添加PowerMock依赖和使用`PowerMockRunner`、`PrepareForTest`注解,以及`PowerMockito.mockStatic`和`verifyStatic`方法进行测试。
22 0
Java一分钟之-PowerMock:静态方法与私有方法测试
|
3天前
|
Java 编译器
17. 【Java教程】Java 方法
17. 【Java教程】Java 方法
13 0
|
6天前
|
存储 Java
深入探索Java语言中的方法
深入探索Java语言中的方法
|
6天前
|
Oracle 安全 Java
JAVA用Mail发送API的方法步骤教程
使用Java和Mail发送API实现自动化邮件发送,提高效率。步骤包括:1. 安装JDK并配置JAVA_HOME,2. 添加JavaMail库(可通过Maven或官网下载)。配置邮件发送涉及邮件服务器地址、端口和认证信息。创建邮件会话、邮件消息对象,然后使用Transport发送。示例代码展示完整流程。注意处理认证失败、连接问题和邮件发送失败等常见问题。
|
7天前
|
Java 开发者
Java的方法的重载
Java的方法的重载
|
7天前
|
存储 Java
Java的方法的声明与使用
Java的方法的声明与使用
|
7天前
|
Java
Java的抽象方法和抽象类
Java的抽象方法和抽象类
|
7天前
|
Java
Java的在类内部调用本类方法
Java的在类内部调用本类方法
|
8天前
|
存储 Java
Java数组与带参数方法:定义、调用及实践
Java数组与带参数方法:定义、调用及实践
18 1