算法总结之欧拉函数中国剩余定理

算法总结之欧拉函数&中国剩余定理

1.欧拉函数

  概念:在数论,对正整数n,欧拉函数是少于或等于n的数中与n互质的数的数目。

  通式:φ(x)=x(1-1/p1)(1-1/p2)(1-1/p3)(1-1/p4)…..(1-1/pn) 

    其中p1, p2……pn为x的所有质因数,x是不为0的整数 

  注意:

    1) φ(1)=1.

    2)每种质因数只一个。比如12=2*2*3那么φ(12)=12*(1-1/2)*(1-1/3)=4

    3)若n是质数p的k次幂,φ(n)=p^k-p^(k-1)=(p-1)p^(k-1),因为除了p的倍数外,其他数都跟n互质。

    4)φ(mn)=φ(m)φ(n)

    5)当n为奇数时,φ(2n)=φ(n)

  代码实现:

1)直接求欧拉数:

 1 /*函数返回值为n的欧拉函数值*/
 2 int euler(int n)
 3 {
 4     int s=n,i,m;
 5     m=sqrt(n);
 6     for(i=2;i<=m;i++){
 7         if(n%i==0)
 8             s=s/i*(i-1);
 9         while(n%i==0)
10             n/=i;
11     }
12     if(n>1)
13         s=s/n*(n-1);
14     return s;
15 }

2)打表

 1 /*打印1-MAXN的欧拉函数表*/
 2 int a[MAXN]= {1,1,0};
 3 void euler()
 4 {
 5     int i,j;
 6     for(i=2; i<=MAXN; i++)
 7         if(!a[i])
 8             for(j=i; j<=MAXN; j+=i)
 9             {
10                 if(a[j]==0) a[j]=j;
11                 a[j]=a[j]/i*(i-1);
12             }
13 }

 2.中国剩余定理

  原文:
    《孙子算经》中的题目:有物不知其数,三个一数余二,五个一数余三,七个一数又余二,问该物总数几何?
    《孙子算经》中的解法:三三数之,取数七十,与余数二相乘;五五数之,取数二十一,与余数三相乘;七七数之,取数十五,与余数二相乘。将诸乘积相加,然后减去一百零五的倍数。

  结论:

    令任意固定整数为M,当M/A余a,M/B余b,M/C余c,M/D余d,…,M/Z余z时,这里的A,B,C,D,…,Z为除数,除数为任意自然数时;余数a,b,c,d,……,z为自然整数时。

    1)当命题正确时,在这些除数的最小公倍数内有解,有唯一的解,每一个最小公倍数内都有唯一的解。

    2)当M在两个或两个以上的除数的最小公倍数内时,这两个或两个以上的除数和余数可以定位M在最小公倍数内的具体位置,也就是M的大小。

    3)正确的命题:分别除以A,B,C,D,…,Z不同的余数组合个数=A,B,C,D,…,Z的最小公倍数=不同的余数组合的循环周期。

  具体步骤(以《孙子算经》中的题目为例):

    1)找出三个数:从3和5的公倍数中找出被7除余1的最小数15,从3和7的公倍数中找出被5除余1 的最小数21,最后从5和7的公倍数中找出除3余1的最小数70。

    2)用15乘以2(2为最终结果除以7的余数),用21乘以3(3为最终结果除以5的余数),同理,用70乘以2(2为最终结果除以3的余数),然后把三个乘积相加(15*2+21*3+70*2)得到和233。

    3)用233除以3,5,7三个数的最小公倍数105,得到余数23,即233%105=23。这个余数23就是符合条件的最小数。

转载于:https://www.cnblogs.com/Enumz/p/3878509.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/493069.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

互联网50年类脑架构技术演化图

作者&#xff1a;刘锋 计算机博士 互联网进化论作者摘要&#xff1a;不断的有著名科学家或企业家提出互联网已死&#xff0c;将被新技术取代&#xff0c;最近绘制了一幅互联网50年的技术演化图&#xff0c;试图说明互联网从1969年四台计算机的网状结构发展成2019类脑结构的过程…

小孔成像中四个坐标系转换

一.小孔成像基础知识: 1.1透镜成像原理 如图所示&#xff1a; 其中 u 为物距&#xff0c; f 为焦距&#xff0c;v 为相距。三者满足关系式&#xff1a; 相机的镜头是一组透镜&#xff0c;当平行于主光轴的光线穿过透镜时&#xff0c;会聚到一点上&#xff0c;这个点叫做焦点&…

不带头结点的单链表的建立

建立该链表利用的是尾插法 // 创建一个单链表&#xff0c;没有头结点&#xff0c; #include <iostream> #include <ctime>using namespace std; //------------------------------------------------ //************************************************ // 结构名…

page.ClientScript.RegisterStartupScript

page.ClientScript.RegisterStartupScript&#xff08;&#xff09;可以添加客户端脚本&#xff0c;有4个参数 type&#xff1a;要注册的启动脚本的类型。key&#xff1a;要注册的启动脚本的键。script&#xff1a;要注册的启动脚本文本。addScriptTags&#xff1a;指示是否添加…

这10项机器人领域的核心技术,你了解多少

来源&#xff1a;机器人创新生态NO 1&#xff0e;人机对话智能交互技术这项技术能让人类做到真正与机器智能的对话交流&#xff0c;机器人不仅能理解用户的问题并给出精准答案&#xff0c;还能在信息不全的情况下主动引导完成会话。当前这一块做得比较成熟的谷歌与Facebook。NO…

leetcode哈希表(python与c++)

1.整数转罗马数字 python: class Solution:def intToRoman(self, num: int) -> str:dict_ {1000:M, 900:CM, 500:D, 400:CD, 100:C, 90:XC, 50:L, 40:XL, 10:X, 9:IX, 5:V, 4:IV, 1:I}res for key in dict_:count num // keyres count * dict_[key]num % keyreturn res…

cs编码规范

HTML 语法HTML5 doctype语言属性&#xff08;Language attribute&#xff09;字符编码IE 兼容模式引入 CSS 和 JavaScript 文件实用为王属性顺序布尔&#xff08;boolean&#xff09;型属性减少标签的数量JavaScript 生成的标签CSS 语法声明顺序媒体查询&#xff08;Media quer…

链表操作时头结点的好处

在链表的开始结点前设置头结点的优点是什么&#xff1f;答&#xff1a;头结点是在链表的开始结点之前附加一个结点。它具有两个优点:&#xff08;1&#xff09;、由于开始结点的位置被存放在头结点的指针域中,所以在链表的第一个位置上的操作就和在表的其它位置上操作一致,无须…

Yann LeCun、吴恩达的新年AI预测:强调“少样本学习”,AI恐慌在减少

来源&#xff1a;大数据文摘新年伊始&#xff0c;海外媒体VentureBeat电话访谈了包括吴恩达、Yann Lecun在内的四位人工智能领域领军者&#xff0c;询问了他们对于过去一年人工智能领域发展的看法&#xff0c;以及他们认为新一年人工智能和机器学习可能产生的突破。不约而同&am…

1.C#WinForm基础制作简单计算器

利用c#语言编写简单计算器&#xff1a; 核心知识点&#xff1a; MessageBox.Show(Convert.ToString(comboBox1.SelectedIndex));//下拉序号MessageBox.Show(Convert.ToString(comboBox1.SelectedItem));//下拉内容MessageBox.Show(Convert.ToString(comboBox1.SelectedText));/…

seaborn的一些画图

一.数据查看 数据集地址,用红白酒为例&#xff0e; import pandas as pd import matplotlib.pyplot as plt from mpl_toolkits.mplot3d import Axes3D import matplotlib as mpl import numpy as np import seaborn as snswhite_wine pd.read_csv(winequality-white.csv, se…

建立带头结点的双向链表_尾插法

// ------------------------------------------------------- //2014--03--14 // 建立双向链表 // 程序分析&#xff1a;双向链表的节点有两个指针域&#xff0c;一个指向直接前驱&#xff0c;另一个指向直接后继。 // 其中第一个节点的前驱指针为NULL &#xff0c;最…

后摩尔定律时代的芯片新选择!

来源&#xff1a;gizmodo摘要&#xff1a;很长一段时间以来&#xff0c;摩尔定律和它的最终结局一直就像房间里的大象&#xff0c;不容忽视。英特尔联合创始人戈登摩尔在1965年的一篇论文中预测&#xff0c;芯片中的晶体管数量每年将翻一番。更多的晶体管意味着更快的速度&…

C++建立队列_利用链表

// c 实现链表队列 // .h 文件 // 文件名&#xff1a; Queue.h //------------------------------------------------- #pragma once//------------------------------------------------- #include <iostream> using namespace std; //------------------------------…

关于Adapter

ArrayAdapter------------>单一值 SimpleAdapter---------->HashMap<String,Object> 多值 BaseAdapter------------>更复杂的数据 SimpleAdapter / BaseAdapter 比较常用 转载于:https://www.cnblogs.com/daishuguang/p/3889143.html

MSE和Cross-entropy梯度更新比较

一.平方损失(MSE) Loss函数: 梯度: 由于x,y是已知的&#xff0c;故可以忽略掉 梯度更新: sigmoid函数: 可以看出 导数在z取大部分值&#xff0c;都是很小的&#xff0c;这样会使梯度更新慢&#xff0e; y为1或0是&#xff0c;当a1,w的梯度为0,a0,w的梯度为0&#xff0c;故就…

麦卡锡问答:什么是人工智能?

来源&#xff1a;科学网一、基本问题问&#xff1a;什么是人工智能&#xff1f;答&#xff1a;人工智能是研制智能机器尤其是智能计算机程序的科学与工程。它与使用计算机理解人类智能类似&#xff0c;但人工智能并不将它自己局限于生物意义上的方法。问&#xff1a;是的&#…

操作系统--多进程管理CPU

一.cpu管理直观做法 最只管想法cpu循环取址执行&#xff0c;所以只需要设好pc初值即可 存在问题:io会占用时间长&#xff0c;导致cpu利用率低. 所以需要不停切换&#xff0c;执行多个程序&#xff0c;也就是并发&#xff0e; 但是在切换的时候&#xff0c;除了记录返回地址&a…

脱裤子放屁,多此一举

脱裤子放屁,多此一举.转载于:https://www.cnblogs.com/zhangzujin/p/3892468.html

胶囊网络、边缘计算:2018年13个最新人工智能发展趋势

来源&#xff1a;亿欧智库摘要&#xff1a; 美国知名研究机构CB Insights的报告《2018年必看的人工智能热门趋势》&#xff0c;对AI行业发展现状进行了深入研究剖析&#xff0c;并给出了2018年AI领域最值得关注的13个前沿发展趋势。趋势一&#xff1a;新蓝领的工作——机器人保…