D5.4 数N在任意进制下每一位的遍历

由"水仙花"数出发,进而考虑回文数(例如,121,1234321...),得到遍历一个数的每一位的方法.

for(i=a ; i<=b ; i++) 其中 i 在循环中完成了[a,b]的遍历;

for(i=a ; i<=b ; i++) 其中 arr[i] 完成了数组一段的遍历;

for(i=n ; i ; i/=10 ) 其中 i % 10 完成了对 n 的每一位的遍历;

for(i=n ; i ; i/=sn) 其中i % sn 完成了对n在sn进制下每一位的遍历.

例1,求0-100000000之间的"水仙花"数

​
​
include <stdio.h>
#include <stdlib.h>
#include <math.h>

int main()
{
    int i, j;
    int tmp[10] = { 0 };
    int sum = 0;
    int count = 0;

    for (i = 0; i < 100000000; i++)
    {
        for (j = i; j; j /= 10)
        {
            tmp[count] = j % 10;// 取出来的数字是逆序的放入数组
                                // 比如135是5,3,1放进去的
            count++;
        }

        for (j = 0; j < count; j++)
        {
            sum += pow(tmp[j], count);
        }

        if (sum == i)
        {
            printf("%d\n", i);
        }
        count = sum = 0;
    }
    system("pause");
    return 0;
}

​

​

例2,判断一个数在任意进制下是否为回文数

#define _CRT_SECURE_NO_WARNINGS
#include <stdio.h>
#include <stdlib.h>
#include <string.h>

int main()
{
    int n;
    int sn;
    int i;
    int tmp, sum = 0;
    scanf("%d %d", &n, &sn);

    for (i = n; i; i /= sn)
    {
        tmp = i % sn;
        sum = sum * sn + tmp;
    }
    if (n == sum)
    {
        printf("%d在%d进制下是回文数\n", n, sn);
    }
    else
    {
        printf("%d在%d进制下不是回文数\n", n, sn);
    }

    system("pause");
    return 0;
}

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值