判断回文数的两种解法

一、首先什么是回文数呢?

“回文”是指正读反读都能读通的句子,它是古今中外都有的一种修辞方式和文字游戏,如“我为人人,人人为我”等。在数学中也有这样一类数字有这样的特征,成为回文数(palindrome number)。

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

二、回文数的解法

判断一个数是否是回文数,有两种思路:
(1)将一个整数翻转,判断翻转后的数是否与原数相等,如果相等则是回文数。

(2)将数字转换成一个字符串,判断这个字符串是否左右相等,如果对称相等,则该数是回文数。

三、代码解析

(1)将整数翻转

//子函数

int IsHuiWenShu(int num)
{
    int n = num;

    while(num!=0)
    {
        temp = temp*10 + num%10;  
        num = num/10;
    }
    if(n == temp)
    {
        return 1;
    }
        else
    {
        return 0;
    }
}
//主函数
int main()
{
    int num = 0;
    int temp = 0;
    int ret = 0;

    printf("请输入一个数: \n");
    scanf("%d", &num);
    ret = IsHuiWenShu(num);
    if(1 == ret)
    {
        printf("是回文数\n");
    }
    else 
    {
        printf("不是回文数\n");
    }

(2)将数字转换为字符串进行判断

int main()
{
    char arr[100] = "";
    int length = 0;
    int n = 0;
    int i = 0;

    scanf("%s", arr);
    length = strlen(arr);
    n = length/2;
    for(i=0; i<=n; i++)  //这里i的终止条件要特别注意
    {
        if(arr[i] == arr[length-1])
        {
            length--;
        }
        else
        {
            break;
        }

    }
    if(arr[i] != arr[length - 1])
    {
        printf("不是回文数\n");
    }
    else 
    {
        printf("是回文数\n");
    }

}

特别注意:这里for循环里边 i 的终止条件千万不要写成 i < length/2,这样会出现问题,当回文数位数比较少时可能还没发现,但回文数的位数多一些的时候就会发现问题
我在这里简单的试了一下,代码如下

int main()
{
    int i = 0;
    int length = 100;

    for(i=0; i<length/2;i++)
    {
        length = length-1;

    }
    printf("循环次数:i = %d\n", i);

    return 0;
}

运行结果如下:

这里写图片描述
如结果所示,假如这个数为100位时,应该要比较50次,而循环只进行了33次。

  • 3
    点赞
  • 17
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
引用中的代码展示了一种求解最长回文子串的暴力解法,即遍历字符串的所有子串,判断是否回文,并记录最长的回文子串。但是这种方法的时间复杂度较高,不适用于较长的字符串。 Python 中有一种更优化的方法来求解最长回文子串,即中心扩展法。该方法的基本思想是从字符串的每个字符和每两个相邻字符之间展开,向两边扩展判断是否回文子串。具体步骤如下: 1. 定义一个函 expandAroundCenter,用于判断以某个中心点向两边扩展的回文子串的长度。 2. 遍历字符串,将每个字符和其相邻字符都作为中心点进行扩展,计算得到回文子串的最大长度。 3. 根据最大长度和中心点位置,确定最长回文子串的起始位置和结束位置。 4. 返回最长回文子串。 下面是基于中心扩展法的 Python 代码示例: ``` class Solution: def longestPalindrome(self, s): if len(s) < 2: return s start, end = 0, 0 for i in range(len(s)): len1 = self.expandAroundCenter(s, i, i) # 以一个字符为中心向两边扩展 len2 = self.expandAroundCenter(s, i, i+1) # 以相邻两个字符为中心向两边扩展 max_len = max(len1, len2) if max_len > end - start: start = i - (max_len - 1) // 2 end = i + max_len // 2 return s[start:end+1] def expandAroundCenter(self, s, left, right): while left >= 0 and right < len(s) and s[left] == s[right]: left -= 1 right += 1 return right - left - 1 s = "ac" S = Solution() result = S.longestPalindrome(s) print(result) ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值