基本的算法总结
1,常数变易法, 如果有代码不知道如何实现,可以用最基本的代码堆砌用常数堆砌好要实现的内容,再将常数找出规律用变量来替代
比如打印输出金字塔。
2,一刀切处理程序逻辑的边缘,特殊位置特殊处理然后用统一的方式来处理整个程序。
3,数字黑洞, 任意一个位数不同的四位数进行这四个数字最大排列数减去这四个数字最小排列数,取到的差再进行上述操作,最后都会只得到一个固定的数字6174,
三位数的黑洞数字是495。还有其他的可以自己编个程序来验证 ,
<span style="font-size:18px;">import java.util.Arrays;
public class suanfa2 {
public static void main(String[] args) {
int s = 6317;
while (true) {
char[] arr = (s+"").toCharArray();
Arrays.sort(arr);
int min = 0, max = 0;
for (int x = 0; x < arr.length; x++)
min = min * 10 + (arr[x] - '0');
//System.out.println(min);
for (int x = arr.length - 1; x >= 0; x--)
max = max * 10 + (arr[x] - '0');
//System.out.println(max);
int s1 = max-min;
if(s==s1)
{
System.out.println(s1);
break;
}
s=s1;
}
}
}</span>