首页 《有趣的回文数》PPT课件

《有趣的回文数》PPT课件

举报
开通vip

《有趣的回文数》PPT课件有趣的回文数制作人:华梓言什么是回文数?中文里,有回文诗句、对联,如:"灵山大佛,佛大山灵","客上天然居,居然天上客"等等,都是美妙的符合正念倒念都一样的回文句.回文数则是有类似22、383、5445、12321,不论是从左向右顺读,还是从右向左倒读,结果都是一样的特征.许多数学家着迷于此。回文数中存在无穷多个素数11,101,131,151,191……。除了11以外,所有回文素数的位数都是奇数。道理很简单:如果一个回文素数的位数是偶数,则它的奇数位上的数字和与偶数位上的数字和必然相等;根据数的整除性理论,容易判...

《有趣的回文数》PPT课件
有趣的回文数制作人:华梓言什么是回文数?中文里,有回文诗句、对联,如:"灵山大佛,佛大山灵","客上天然居,居然天上客"等等,都是美妙的符合正念倒念都一样的回文句.回文数则是有类似22、383、5445、12321,不论是从左向右顺读,还是从右向左倒读,结果都是一样的特征.许多数学家着迷于此。回文数中存在无穷多个素数11,101,131,151,191……。除了11以外,所有回文素数的位数都是奇数。道理很简单:如果一个回文素数的位数是偶数,则它的奇数位上的数字和与偶数位上的数字和必然相等;根据数的整除性理论,容易判断这样的数肯定能被11整除,所以它就不可能是素数。什么是回文数?人们借助电子计算机发现,在完全平方数、完全立方数中的回文数,其比例要比一般自然数中回文数所占的比例大得多。例如112=121,222=484,73=343,113=1331……都是回文数。人们迄今未能找到四次方、五次方,以及更高次幂的回文素数。于是数学家们猜想:不存在nk(k≥4;n、k均是自然数)形式的回文数。在电子计算器的实践中,还发现了一桩趣事:任何一个自然数与它的倒序数相加,所得的和再与和的倒序数相加,……如此反复进行下去,经过有限次步骤后,最后必定能得到一个回文数。判断回文数    一个经典的题目,而且有一种经典的算法,也是当时我遇到的那个题目的 标准 excel标准偏差excel标准偏差函数exl标准差函数国标检验抽样标准表免费下载红头文件格式标准下载 答案。    回文数,即一个整数,无论从左到右看还是从右到左看都是同一个数字,即以中间的那个数字左右对称。例如737,59395,12321之类的。判断回文数经典的算法是:分别用整除和模除求出两端的数位,然后比较,如果相同,则去掉这两个数位,再次求出新的两端的数位,再比较,如此循环,直到出现不相同就可以判断不是回文数,或者到了中间的数位仍然相同的话就为回文数,这种算法的优点是,在排除非回文数的时候会快一些,因为不一定要比较到中间那位也许一开始的头尾两位就已经不相同了,那么这个判断的过程就可以很快结束了,在时间复杂度上也许会快一些,但缺点也是显然的,就是如果所判断数就是回文数的话,则必须对每一对数位都作比较,而且在判断是否为中位即结束位置的时候就比较困难了,还要分奇数位和偶数位,甚至还要先求出数字的数位长度。判断回文数我的算法是:用模除10读出低位数位,然后入队列,然后用整除10删除这个数位,再用模除10读出新的最低位,再入列,再整除10删除这个数位,如此循环,终止条件是整除后已经为0了,这样就表示整个数都已经从低到高位逐位入列了。然后原来的从低位开始出列,出一位就乘10,然后再出一位累加,再乘10,再累加,直到所有的数位都出列,实际上出来的结果就是把原来的数字倒序了一次,由于倒序后仍然是一个数字,所以可以直接将原来的数字和倒序后的数字比较,如果相同即为回文数,否则不是判断回文数以上说的只是编程的实现细节,简述一下思路,实际上就是利用了回文数的特点,就是以中线两端对称,所以我就先生成一个原数的镜像数--即高低位倒序了一下,如果是回文数的话,肯定和他的镜像数相同的,而且由于倒序了后仍是一个整数,不是字符串,所以可以直接作两个整数的比较操作就行了,不用逐个数位比较,所以无论这个要判断的数多长多大,都只是作了一次整数比较而已。但缺点也是有的,就是一定要把整个整数的所有数位都读出一次,然后再写进并构造另一个整数。但由于比较次数大大减少,在判断一个较长较大的整数时,未必就是更耗费时间的,而且实现起来简单很多,尤其是判断终止的时候比较简单判断回文数另外,上面所说借助队列也只是为了说明的更加清晰更加易懂而已,用堆栈来实现是同样的道理,这只是为了构造那个倒序数的一个手段而已,实际上,细心考虑一下,其实可以根本不必借助这些数据结构的,在读出了低位后直接就写入新的那个倒序数就可以了,代码如下:(C++)bool is_huiwen(long number,int rad){//number是要判断的整数,rad是判断基于的数制,一般为10进制,即rad等于10,也可以等于2,8,16等//返回的是一个bool类型的值,为true即number是回文数,为false则否    long num=number;                      //原数    long num_reverse=0;                   //倒序数    if(num<0) num=0-num;                  //负数也作判断,先转为正数    if(num>=0 && num
本文档为【《有趣的回文数》PPT课件】,请使用软件OFFICE或WPS软件打开。作品中的文字与图均可以修改和编辑, 图片更改请在作品中右键图片并更换,文字修改请直接点击文字进行修改,也可以新增和删除文档中的内容。
该文档来自用户分享,如有侵权行为请发邮件ishare@vip.sina.com联系网站客服,我们会及时删除。
[版权声明] 本站所有资料为用户分享产生,若发现您的权利被侵害,请联系客服邮件isharekefu@iask.cn,我们尽快处理。
本作品所展示的图片、画像、字体、音乐的版权可能需版权方额外授权,请谨慎使用。
网站提供的党政主题相关内容(国旗、国徽、党徽..)目的在于配合国家政策宣传,仅限个人学习分享使用,禁止用于任何广告和商用目的。
下载需要: 免费 已有0 人下载
最新资料
资料动态
专题动态
个人认证用户
香香
暂无简介~
格式:ppt
大小:196KB
软件:PowerPoint
页数:10
分类:
上传时间:2022-12-20
浏览量:3