武功秘籍
小明到X山洞探险,捡到一本有破损的武功秘籍(2000多页!当然是伪造的)。他注意到:书的第10页和第11页在同一张纸上,但第11页和第12页不在同一张纸上。
小明只想练习该书的第81页到第92页的武功,又不想带着整本书。请问他至少要撕下多少张纸带走?
这是个整数,请通过浏览器提交该数字,不要填写任何多余的内容。
答案:7
要注意的是书本2000多页就是1000多张纸叠在一起中间用线缝合,依照题意符合条件的情况大致如图:
那么他想要学习第81页到第92页的武功,就需要[80/81] [82/83] [84/85] [86/87] [88/89] [90/91] [92/93]这7张纸。
切面条
一根高筋拉面,中间切一刀,可以得到2根面条。
如果先对折1次,中间切一刀,可以得到3根面条。
如果连续对折2次,中间切一刀,可以得到5根面条。
那么,连续对折10次,中间切一刀,会得到多少面条呢?
答案是个整数,请通过浏览器提交答案。不要填写任何多余的内容。
答案:1025
可以用纸折几下找到规律:
对折次数: 0 1 2 3 4....n
切后面条数量:2 3 5 9 17...x
所以x=(1+2^n)
即答案为:1+2^10=1025。
猜字母
把abcd…s共19个字母组成的序列重复拼接106次,得到长度为2014的串。
接下来删除第1个字母(即开头的字母a),以及第3个,第5个等所有奇数位置的字母。
得到的新串再进行删除奇数位置字母的动作。如此下去,最后只剩下一个字母,请写出该字母。
答案是一个小写字母,请通过浏览器提交答案。不要填写任何多余的内容。
答案:q
代码如下:
public class Main{
public static void main(String[] args) {
char[] a=new char[2014];
int index=0;
for (int i=0;i<106;i++){
for (int j=0;j<19;j++){
a[index++]=(char)('a'+j);
}
}
int len=2014;
while (len!=1){
int k=0;
for (int i=1;i<len;i+=2){
a[k++]=a[i];
}
len=k;
}
System.out.println(a[0]);
}
}
大衍数列
中国古代文献中,曾记载过“大衍数列”, 主要用于解释中国传统文化中的太极衍生原理。
它的前几项是:0、2、4、8、12、18、24、32、40、50 …
其规律是:对偶数项,是序号平方再除2,奇数项,是序号平方减1再除2。
以下的代码打印出了大衍数列的前 100 项。
for(int i=1; i<100; i++){ if(________________) //填空 System.out.println(i*i/2); else System.out.println((i*i-1)/2); }
请填写划线部分缺失的代码。通过浏览器提交答案。
注意:不要填写题面已有的内容,也不要填写任何说明、解释文字。
答案:i%2==0
圆周率
数学发展历史上,圆周率的计算曾有许多有趣甚至是传奇的故事。其中许多方法都涉及无穷级数。
图1.png中所示&