《关于当代大学生被一道初中数学题难住所得灵感写的一道Java版智慧数》题目是这样的:
一个正整数如果能表示成了两个正整数的平方差,则称这个数为“智慧数”,比如16就等于5的平方减去3的平方,所以16就是一个智慧数,从1开始的自然数列中,将“智慧数”从小到大编号为1,2,3,„„,n。现输入一个正整数n,求第2006个“智慧数”。
输入
3
输出
7
输入4
输出8
这道题我是根据纯数学理论所做,如果有大佬有更好的方法,请在评论里指点我一下。
//函数体 public int number(int n){ if(n<4){ if(n==1){ return 3; }else if(n==2){ return 5; }else if(n==3){ return 7; }else { return 0; } }else { if(n%3==0){ int num =(int) 4*(n/3)+3; return num; }else if(n%3==1){ int num = (int) 4*((n/3)+1); return num; }else { int num = (int) 4*((n/3)+1)+1; return num; } } }