自守数算法----C语言实现

简介: #include //自守数算法//ep : 25 ^ 2 = 625 76 ^ 2 = 5776 9376 ^ 2 = 87909376/*ep : * 376 被乘数 * *376 乘数 * ------ --------- * 2256 第一个部分积=被乘数*乘数的倒数第一位 * 2632 第二个部分积=被乘数*乘数的倒数第三位 * 1125 第三个部分积=被乘数*乘数的倒数第三位 *-------- * 141376 将以上的部分积的后3位求和后截取后3位就是3位数乘积的后3位。
#include <stdio.h>
//自守数算法
//ep : 25 ^ 2 = 625   76 ^ 2 = 5776  9376 ^ 2 = 87909376
/*ep :
 *   376      被乘数
 *  *376        乘数
 *  ------  ---------
 *   2256     第一个部分积=被乘数*乘数的倒数第一位
 *  2632      第二个部分积=被乘数*乘数的倒数第三位
 * 1125       第三个部分积=被乘数*乘数的倒数第三位
 *--------
 * 141376
 将以上的部分积的后3位求和后截取后3位就是3位数乘积的后3位。
*/

/*由number的位数确定截取数字进行乘法时的系数k*/
#define forech_bit_num(mul,number,k)  \
            for(mul=number,k=1;(mul/=10)>0;k*=10) ;
//在0~xxxx这些数中寻找自守数
#define forech_number(number,num)     \
            for(number=0;number<num;number++)
//自守数核心算法:(部分积+截取被乘数的后N位*截取乘数的第M位),%kk再截取部分积
#define automorphic_number(mul,number,k,ll,kk)   \
        mul=(mul+(number%(k*10))*(number%ll-number%(ll/10)))%kk;
long print_automorphic_number(long num)
{
    long mul,number,k,ll,kk;
    forech_number(number,num)
    {
        forech_bit_num(mul,number,k);
        kk=k*10;      /*kk为截取部分积时的系数*/
        mul=0;        /*积的最后n位*/
        ll=10;        /*ll为截取乘数相应位时的系数*/
        while(k > 0)
        {
            automorphic_number(mul,number , k ,ll ,kk);
            k/=10;               /*k为截取被乘数时的系数*/
            ll*=10;
        }
         if(number==mul){         /*判断若为自守数则输出*/
              printf("%ld   ", number);
         }
    }

}


int main(void)
{
    print_automorphic_number(1000);
    return 0 ;
}

目录
相关文章
|
28天前
|
自然语言处理 算法 搜索推荐
C语言中谈论算法
C语言中谈论算法
10 0
C语言中谈论算法
|
1月前
|
算法 安全 C语言
使用C语言实现DES算法代码
使用C语言实现DES算法代码
|
1月前
|
算法 搜索推荐 C语言
C语言的算法
C语言的算法
17 0
|
1月前
|
自然语言处理 算法 搜索推荐
C语言用伪代码表示算法
C语言用伪代码表示算法
25 0
|
15天前
|
算法 C语言
【算法与数据结构】 C语言实现单链表队列详解2
【算法与数据结构】 C语言实现单链表队列详解
|
15天前
|
存储 算法 C语言
【算法与数据结构】 C语言实现单链表队列详解1
【算法与数据结构】 C语言实现单链表队列详解
|
25天前
|
存储 机器学习/深度学习 算法
C语言代码实现数据结构与算法
以上代码中,哈希表使用链表解决哈希冲突,每个链表节点包含一个键值对。hash函数用于计算键值对应的哈希值,insert函数用于向哈希表中插入一个键值对,若当前位置为空,则直接插入;否则,将新节点插入到链表末尾。search函数用于在哈希表中查找指定键值的值,若存在则返回其值,否则返回-1。
32 1
|
28天前
|
搜索推荐 算法 C语言
C语言排序算法
C语言排序算法
13 0
|
1月前
|
算法 数据处理 C语言
C语言核心之一的算法结构
C语言核心之一的算法结构
13 1
|
1月前
|
算法 搜索推荐 C语言
C语言的算法
C语言的算法
14 1