写几个数字杂技
2020-03-01 本文已影响0人
西5d
刚开始写代码的时候,会首先接触一些练习,所以今天记录几个简单的数字有关的,亲自上手写,也花不了多少时间,当然也会有不同的实现方式,就当练练脑子。
打印数字三角
public void printTriangle(){
for (int i = 1; i < 10; i++) {
for (int j = 1; j <= i; j++) {
System.out.print(j + " ");
}
System.out.println();
}
}
out:
1
1 2
1 2 3
1 2 3 4
1 2 3 4 5
1 2 3 4 5 6
1 2 3 4 5 6 7
1 2 3 4 5 6 7 8
1 2 3 4 5 6 7 8 9
平衡的数字三角
public void printBalanceTriangle(){
int space = 10;
for (int i = 1; i < 10; i++) {
for (int j = 0; j < space; j++) {
System.out.print(" ");
}
for (int j = 1; j <= i; j++) {
System.out.print(j + " ");
}
space-=1;
System.out.println();
}
}
out:
1
1 2
1 2 3
1 2 3 4
1 2 3 4 5
1 2 3 4 5 6
1 2 3 4 5 6 7
1 2 3 4 5 6 7 8
1 2 3 4 5 6 7 8 9
乘法表
public void printMultiTable(){
for (int i = 1; i <= 9; i++) {
for (int j = 1; j <= 9; j++) {
System.out.print(i + "x" + j + "=" + i*j + "\t");
if(j>=i){
break;
}
}
System.out.println();
}
}
out:
1x1=1
2x1=2 2x2=4
3x1=3 3x2=6 3x3=9
4x1=4 4x2=8 4x3=12 4x4=16
5x1=5 5x2=10 5x3=15 5x4=20 5x5=25
6x1=6 6x2=12 6x3=18 6x4=24 6x5=30 6x6=36
7x1=7 7x2=14 7x3=21 7x4=28 7x5=35 7x6=42 7x7=49
8x1=8 8x2=16 8x3=24 8x4=32 8x5=40 8x6=48 8x7=56 8x8=64
9x1=9 9x2=18 9x3=27 9x4=36 9x5=45 9x6=54 9x7=63 9x8=72 9x9=81
汉字乘法表
public void printMultiTableHan(){
String[] hans = new String[]{"一","二","三","四","五","六","七","八","九"};
int r;
String s;
String line;
for (int i = 1; i <= 9; i++) {
for (int j = 1; j <= 9; j++) {
r = i*j;
if(r < 10){
s = "得" + hans[r-1];
}else {
if(r%10==0){
s = hans[r/10-1] + "十";
}else {
s = hans[r/10-1] + "十" + hans[r%10-1];
}
}
line = hans[j-1] + hans[i-1] + s + " ";
System.out.print(line);
if(j>=i){
break;
}
}
System.out.println();
}
}
out :
一一得一
一二得二 二二得四
一三得三 二三得六 三三得九
一四得四 二四得八 三四一十二 四四一十六
一五得五 二五一十 三五一十五 四五二十 五五二十五
一六得六 二六一十二 三六一十八 四六二十四 五六三十 六六三十六
一七得七 二七一十四 三七二十一 四七二十八 五七三十五 六七四十二 七七四十九
一八得八 二八一十六 三八二十四 四八三十二 五八四十 六八四十八 七八五十六 八八六十四
一九得九 二九一十八 三九二十七 四九三十六 五九四十五 六九五十四 七九六十三 八九七十二 九九八十一
非递归的斐波拉契数列
@Test
public void printFib(){
long a = 1, b = 1;
long x;
System.out.println(a);
System.out.println(b);
for (int i = 0; i < 40; i++) {
x = a + b;
a = b;
b = x;
System.out.println(x);
}
}
递归的斐波拉契
@Test
public void printFibRecursive(){
for (int i = 0; i < 40; i++) {
System.out.println(fib(i+1));
}
}
private long fib(long a){
if(a <= 2){
return 1;
}else {
return fib(a -1) + fib(a -2);
}
}
好了,到这结束,挺多的几个,数字相关的东西还是很有意思的。