当前位置: 首页 > news >正文

判断回文数

文章目录

  • 题目palindrome-number
  • 代码
    • c语言
    • java语言
    • 只判断一半的方法
  • 参考资料

题目palindrome-number

判断一个数是否为回文数。

设n是一任意自然数。若将n的各位数字反向排列所得自然数n1与n相等,则称n为一回文数。例如,若n=1234321,则称n为一回文数;但若n=1234567,则n不是回文数

代码

c语言

#include <stdio.h>
 
int main()
{
    int n, reversedInteger = 0, remainder, originalInteger;
 
    printf("输入一个整数: ");
    scanf("%d", &n);
 
    originalInteger = n;
 
    // 翻转
    while( n!=0 )
    {
        remainder = n%10;
        reversedInteger = reversedInteger*10 + remainder;
        n /= 10;
    }
 
    // 判断
    if (originalInteger == reversedInteger)
        printf("%d 是回文数。", originalInteger);
    else
        printf("%d 不是回文数。", originalInteger);
    
    return 0;
}

运行结果:

输入一个整数: 12321
12321 是回文数

java语言

package palindrome_number;

public class Solution {
	
	public static boolean isPalindrome(int x) {
		if(x<0)return false;
		int orig = x;
		int pop = 0;//个位
		int res = 0;//反转后的数
		//翻转
		while(x!=0) {
			pop = x%10;
			res = res*10+pop;
			x/=10;
		}
		//判断
		if(orig==res) {
			return true;
		}
		return false;
	}
	
	public static void main(String[] args) {
		System.out.println(Solution.isPalindrome(123123));
		System.out.println(Solution.isPalindrome(12321));
	}
	
}

执行结果:

通过
显示详情
执行用时 :9 ms, 在所有 java 提交中击败了99.10%的用户
内存消耗 :36.1 MB, 在所有 java 提交中击败了97.12%的用户

只判断一半的方法

为了避免数字反转可能导致的溢出问题,为什么不考虑只反转 int 数字的一半?毕竟,如果该数字是回文,其后半部分反转后应该与原始数字的前半部分相同。

现在的问题是,我们如何知道反转数字的位数已经达到原始数字位数的一半?

我们将原始数字除以 10,然后给反转后的数字乘上 10,所以,当原始数字小于反转后的数字时,就意味着我们已经处理了一半位数的数字。

public class Solution {
    public bool IsPalindrome(int x) {
        // 特殊情况:
        // 如上所述,当 x < 0 时,x 不是回文数。
        // 同样地,如果数字的最后一位是 0,为了使该数字为回文,
        // 则其第一位数字也应该是 0
        // 只有 0 满足这一属性
        if(x < 0 || (x % 10 == 0 && x != 0)) {
            return false;
        }

        int revertedNumber = 0;
        while(x > revertedNumber) {
            revertedNumber = revertedNumber * 10 + x % 10;
            x /= 10;
        }

        // 当数字长度为奇数时,我们可以通过 revertedNumber/10 去除处于中位的数字。
        // 例如,当输入为 12321 时,在 while 循环的末尾我们可以得到 x = 12,revertedNumber = 123,
        // 由于处于中位的数字不影响回文(它总是与自己相等),所以我们可以简单地将其去除。
        return x == revertedNumber || x == revertedNumber/10;
    }
}

参考资料

C 语言实例 - 判断回文数

相关文章:

  • 两数相加_详解
  • 第N高的薪水
  • 合并两个有序链表(merge-two-sorted-lists)
  • 移除元素remove-element
  • 删除排序数组中的重复项Remove Duplicates from Sorted Array
  • 字符串转换整数 (string-to-integer-atoi)
  • 最长公共前缀(longest-common-prefix)
  • 罗马数字转整数(roman-to-integer)
  • 删除链表的倒数第N个节点(remove-nth-node-from-end-of-list)
  • 为什么说合数它一定能够被某个素数整除?
  • 实现 strStr()采用kmp算法
  • translate-shell的使用方法
  • ksnapshot使用
  • 报数count-and-say
  • 递归需要遵守的重要规则
  • Android单元测试 - 几个重要问题
  • Angular 响应式表单 基础例子
  • Bytom交易说明(账户管理模式)
  • ES10 特性的完整指南
  • Git同步原始仓库到Fork仓库中
  • Java Agent 学习笔记
  • Java|序列化异常StreamCorruptedException的解决方法
  • Java方法详解
  • mysql_config not found
  • ReactNativeweexDeviceOne对比
  • SOFAMosn配置模型
  • Solarized Scheme
  • 简单实现一个textarea自适应高度
  • 如何用Ubuntu和Xen来设置Kubernetes?
  • 深度学习入门:10门免费线上课程推荐
  • 深入体验bash on windows,在windows上搭建原生的linux开发环境,酷!
  • 我的zsh配置, 2019最新方案
  • 项目实战-Api的解决方案
  • 异常机制详解
  • 原创:新手布局福音!微信小程序使用flex的一些基础样式属性(一)
  • puppet连载22:define用法
  • ​iOS安全加固方法及实现
  • #android不同版本废弃api,新api。
  • (12)Hive调优——count distinct去重优化
  • (保姆级教程)Mysql中索引、触发器、存储过程、存储函数的概念、作用,以及如何使用索引、存储过程,代码操作演示
  • (超详细)2-YOLOV5改进-添加SimAM注意力机制
  • (二)pulsar安装在独立的docker中,python测试
  • (附源码)spring boot校园拼车微信小程序 毕业设计 091617
  • (九)信息融合方式简介
  • (三)uboot源码分析
  • (转)程序员疫苗:代码注入
  • .NET CF命令行调试器MDbg入门(二) 设备模拟器
  • .NET CLR基本术语
  • .net core 6 redis操作类
  • .Net MVC4 上传大文件,并保存表单
  • .NET Remoting学习笔记(三)信道
  • .net 发送邮件
  • .Net 中Partitioner static与dynamic的性能对比
  • .NET/C# 利用 Walterlv.WeakEvents 高性能地定义和使用弱事件
  • .NET:自动将请求参数绑定到ASPX、ASHX和MVC(菜鸟必看)