我们都写过这个程序:
它会输出:
于是很自然地,要写出一个输出自己的程序,可以尝试这样写:
main() { printf("#include<stdio.h>\nmain() { printf(\"#include<stdio.h>\n main() { ...\") } ");}
它会输出:
你可以继续这样写下去,但你会发现自己已经陷入死循环了,写到printf那就得返回去加上一段。显然像上面这样是做不到的。是不是说这样的程序就不存在呢?答案是否定的,不仅写得出来,而且各种各样,五花八门的都有。
能否找到五个连续的整数,使前面的四个数的四次方之和等于最后一个数的四次方?
解答:也许你用Mathematica算出很长一个表达式,显然不是整数。事实确实是找不到,证明很简单:我们考虑下一个数的四次方被5除的余数,可以只看这几个数5k,5k+1,5k+2,5k+3,5k+4,可以看出余数分别是0,1,1,1,1。这样当把前前4个余数起来只能是3或4,这样就证明了无解了。
求b,使得在b进制下35(b)和58(b)互质(即最大公约数是1)。
解答:显然b>=9,因为58中含有数字8。我们知道35(b)=3*b+5,58(b)=5*b+8。假设d是它们的任意一个公约数。则d整除5*35(b)-3*58(b)=5*(3*b+5)-3*(5*b+8)=1。
所以d一定整除1,这样d=1。所以35(b)和58(b)在任何其底b>=9下都互质。
找出若干个正整数n1,n2,n3,...nk,使满足n1+n2+n3+...+nk=100,并且它们的乘积要是最大的?
解答:假设我们已经有了一个对100的分割并且它们的乘积是最大的,显然这个分割中不能包含1,因为我们可以去掉1,并在其它任一项上加1则得到的乘积更大。分割中也不能包含大于4的偶数k,因为我们可以用k/2和k/2去代替,由于k>4,k^2>4k,这样(k/2)*(k/2)>k,这样得到乘积更大的分割。同样,分割中不能包含大于4的奇数k,我们可以用(k-1)/2和(k+1)/2代替它,由于k>=5,可以得到k^2>=5k>4k+1,于是((k-1)/2)*((k+1)/2)>k,乘积变得更大了。这样一来分割中只含有2,3和4。而分割中不能包含1个以上的4,因为两个4可以被3,3,2代替得到更大的乘积(3*3*2>4*4)。分割中也不能含有2个以上的2,因为3个2可以被两个3代替得到更大的乘积(3*3>2*2*2)。最后分割中还不能同时含有4和2,因为它们可以被两个3代替得到更大的乘积(3*3>4*2)。结果分割中只能3,一个4或者最多两个2,考虑到和为100,就只能分成32个3和1个4(或者2个2)。
给大家介绍一个网站,进去后它会随机出25道与Pi相关的问题,这些问题大多是一些琐碎的关于Pi的历史,应用,秘闻之类的。难度还是相当大的。