簡單算法-寫幾個數字雜技

剛開始寫代碼的時候,會首先接觸一些練習,所以今天記錄幾個簡單的數字有關的,親自上手寫,也花不了多少時間,當然也會有不同的實現方式,就當練練腦子。

打印數字三角

<code> public void printTriangle(){
for (int i = 1; i < 10; i++) {
for (int j = 1; j <= i; j++) {
System.out.print(j + " ");
}
System.out.println();
}
}
/<code>

out:

<code>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
/<code>


簡單算法-寫幾個數字雜技


平衡的數字三角

<code>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();
}
}
/<code>

out:

<code>          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
/<code>

乘法表

<code>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();
}
}
/<code>

out:

<code>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
/<code>

漢字乘法表

<code>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();
}
}
/<code>

out :

<code>一一得一  

一二得二 二二得四
一三得三 二三得六 三三得九
一四得四 二四得八 三四一十二 四四一十六
一五得五 二五一十 三五一十五 四五二十 五五二十五
一六得六 二六一十二 三六一十八 四六二十四 五六三十 六六三十六
一七得七 二七一十四 三七二十一 四七二十八 五七三十五 六七四十二 七七四十九
一八得八 二八一十六 三八二十四 四八三十二 五八四十 六八四十八 七八五十六 八八六十四
一九得九 二九一十八 三九二十七 四九三十六 五九四十五 六九五十四 七九六十三 八九七十二 九九八十一

/<code>

非遞歸的斐波拉契數列

<code>@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);
}
}
/<code>

遞歸的斐波拉契

<code>
@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);
}
}
/<code>

好了,到這結束,挺多的幾個,數字相關的東西還是很有意思的。


分享到:


相關文章: