1 / 10
文档名称:

《有趣的回文数》.ppt

格式:ppt   大小:643KB   页数:10页
下载后只包含 1 个 PPT 格式的文档,没有任何的图纸或源代码,查看文件列表

如果您已付费下载过本站文档,您可以点这里二次下载

分享

预览

《有趣的回文数》.ppt

上传人:相惜 2024/4/17 文件大小:643 KB

下载得到文件列表

《有趣的回文数》.ppt

相关文档

文档介绍

文档介绍:该【《有趣的回文数》 】是由【相惜】上传分享,文档一共【10】页,该文档可以免费在线阅读,需要了解更多关于【《有趣的回文数》 】的内容,可以使用淘豆网的站内搜索功能,选择自己适合的文档,以下文字是截取该文章内的部分文字,如需要获得完整电子版,请下载此文档到您的设备,方便您编辑和打印。有趣的回文数制作人:华梓言编辑课件什么是回文数?中文里,有回文诗句、对联,如:"灵山大佛,佛大山灵","客上天然居,居然天上客"等等,都是美妙的符合正念倒念都一样的回文句. 回文数那么是有类似22、383、5445、12321,不管是从左向右顺读,还是从右向左倒读,。 回文数中存在无穷多个素数11,101,131,151,191……。除了11以外,所有回文素数的位数都是奇数。道理很简单:如果一个回文素数的位数是偶数,那么它的奇数位上的数字和与偶数位上的数字和必然相等;根据数的整除性理论,容易判断这样的数肯定能被11整除,所以它就不可能是素数。编辑课件什么是回文数?人们借助电子计算机发现,在完全平方数、完全立方数中的回文数,其比例要比一般自然数中回文数所占的比例大得多。例如112=121,222=484,73=343,113=1331……都是回文数。 人们迄今未能找到四次方、五次方,以及更高次幂的回文素数。于是数学家们猜测:不存在nk(k≥4;n、k均是自然数)形式的回文数。 在电子计算器的实践中,还发现了一桩趣事:任何一个自然数与它的倒序数相加,所得的和再与和的倒序数相加,……如此反复进行下去,经过有限次步骤后,最后必定能得到一个回文数。编辑课件判断回文数一个经典的题目,而且有一种经典的算法,也是当时我遇到的那个题目的标准答案。 ????回文数,即一个整数,无论从左到右看还是从右到左看都是同一个数字,即以中间的那个数字左右对称。例如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<rad)?return?true;????//只有一个数位那么直接返回true,不必再做编辑课件判断回文数下面的比较 ????while(num){???????????????????????????//原数num为0那么终止 ????????num_reverse*=rad;?????????????????//倒序数增位 ????????num_reverse+=num%rad;?????????????//求出当前的最低位并加到新的倒序数上 ????????num=num/rad;??????????????????????//原数num去掉最低位 ????} ????if(number==num_reverse)???????????????//只作一次比较,而且只是整数比较 ????????return?true; ????else ????????return?false;编辑课件再见编辑课件