九九乘法表
public class Test1 {
public static void main(String[] args) {
for(int i = 1; i <= 9; i++){
for(int j = 1; j <= 9; j++){
if(i >= j){
System.out.print(j + "*" + i + "=" + j * i + "\t");
}
}
System.out.println();
}
}
}
1*1=1
1*2=2 2*2=4
1*3=3 2*3=6 3*3=9
1*4=4 2*4=8 3*4=12 4*4=16
1*5=5 2*5=10 3*5=15 4*5=20 5*5=25
1*6=6 2*6=12 3*6=18 4*6=24 5*6=30 6*6=36
1*7=7 2*7=14 3*7=21 4*7=28 5*7=35 6*7=42 7*7=49
1*8=8 2*8=16 3*8=24 4*8=32 5*8=40 6*8=48 7*8=56 8*8=64
1*9=9 2*9=18 3*9=27 4*9=36 5*9=45 6*9=54 7*9=63 8*9=72 9*9=81
思路分析走一波
1. 最直接的肯定第一反应是要循环9次,然后要嵌套循环
2. 外层循环一次,内层循环就要循环9次
3. 内层循环打印次数要和外层的一样,所以就限制内层循环次数
4. 大概就这样
冒泡排序
例如:冒泡:从小到大,从左到右两两比较
/*
{6,3,8,2,9,1}
第一轮:
第1次:arr[0]与arr[1]比较,6>3成立,就交换,{3,6,8,2,9,1}
第2次:arr[1]与arr[2]比较,6>8不成立,不交换{3,6,8,2,9,1}
第3次:arr[2]与arr[3]比较,8>2成立,就交换,{3,6,2,8,9,1}
第4次:arr[3]与arr[4]比较,8>9不成立,不交换{3,6,2,8,9,1}
第5次:arr[4]与arr[5]比较,9>1成立,就交换,{3,6,2,8,1,9}
第一轮结果:{3,6,2,8,1,9} 9已经到达正确位置,下一轮不用在参与
第二轮:
第1次:arr[0]与arr[1]比较,3>6不成立,不交换{3,6,2,8,1,9}
第2次:arr[1]与arr[2]比较,6>2成立,就交换,{3,2,6,8,1,9}
第3次:arr[2]与arr[3]比较,6>8不成立,不交换{3,2,6,8,1,9}
第4次:arr[3]与arr[4]比较,8>1成立,就交换,{3,2,6,1,8,9}
第二轮结果:{3,2,6,1,8,9} 8已经到达正确位置,下一轮不用在参与
第三轮:
第1次:arr[0]与arr[1]比较,3>2成立,就交换,{2,3,6,1,8,9}
第2次:arr[1]与arr[2]比较,3>6不成立,不交换{2,3,6,1,8,9}
第3次:arr[2]与arr[3]比较,6>1成立,就交换,{2,3,1,6,8,9}
第三轮结果:{2,3,1,6,8,9} 6已经到达正确位置,下一轮不用在参与
第四轮:
第1次:arr[0]与arr[1]比较,2>3不成立,不交换{2,3,1,6,8,9}
第2次:arr[1]与arr[2]比较,3>1成立,就交换,{2,1,3,6,8,9}
第四轮结果:{2,1,3,6,8,9} 3已经到达正确位置,下一轮不用在参与
第五轮
第1次:arr[0]与arr[1]比较,2>1成立,就交换,{1,2,3,6,8,9}
第五轮结果:{1,2,3,6,8,9} 2已经到达正确位置,下一轮不用在参与
剩下1,肯定是最小的了,不用比较了
6个元素,比较了5轮, n个元素需要n-1轮
每一轮比较很多次
*/
示例代码:
public static void main(String[] args){
int[] arr = {6,3,8,2,9,1}; //arr.length = 6
//i=1,2,3,4,5 一共5轮
for(int i=1; i<arr.length; i++){//轮数
/*
i=1,第1轮,j=0,1,2,3,4 arr[j]与arr[j+1]
i=2,第2轮,j=0,1,2,3 arr[j]与arr[j+1]
i=3,第3轮,j=0,1,2 arr[j]与arr[j+1]
i=4,第4轮,j=0,1 arr[j]与arr[j+1]
i=5,第5轮,j=0 arr[j]与arr[j+1]
j=0, j<=arr.length-1-i
*/
for(int j=0; j<=arr.length-1-i; j++){
if(arr[j] > arr[j+1]){
int temp = arr[j];
arr[j] = arr[j+1];
arr[j+1] = temp;
}
}
}
//结果
for(int i=0; i<arr.length; i++){
System.out.print(arr[i] + " ");
}
}
示例代码:从大到小,从右到左
char[] arr = {'h','e','l','l','o','j','a','v','a'};
for(int i=1; i<arr.length; i++){//外循环的次数 = 轮数 = 数组的长度-1
/*
第1轮,i=1,从右到左两两比较,arr[8]与arr[7],arr[7]与arr[6]....arr[1]与arr[0]
第2轮,i=2,从右到左两两比较,arr[8]与arr[7],arr[7]与arr[6]....arr[2]与arr[1]
...
第8轮,i=8,从右到左两两比较,arr[8]与arr[7]
arr[j]与arr[j-1]
找两个关键点:(1)j的起始值:8(2)找j的终止值,依次是1,2,3,。。。8,得出j>=i
*/
for(int j=8; j>=i; j--){
//从大到小,后面的元素 > 前面的元素,就交换
if(arr[j]>arr[j-1]){
int temp = arr[j];
arr[j] = arr[j-1];
arr[j-1] = temp;
}
}
}
理解不了冒泡的自己画个图,理解一下
在java中永远不会执行的代码,jvm会报错
杨辉三角
int[][] arr = new int[10][];
for(int i = 0 ; i< arr.length; i++){
arr[i] = new int[i+1];
for(int j = 0; j < arr[i].length; j++){
if(j == 0 || j == arr[i].length - 1){
arr[i][j] = 1;
}else{
arr[i][j] = arr[i-1][j-1] + arr[i-1][j];
}
}
}
for (int i = 0; i < arr.length; i++) {
for (int j = 0; j < arr[i].length; j++) {
System.out.print(arr[i][j] + "\t");
}
System.out.println();
}
1
1 1
1 2 1
1 3 3 1
1 4 6 4 1
1 5 10 10 5 1
1 6 15 20 15 6 1
1 7 21 35 35 21 7 1
1 8 28 56 70 56 28 8 1
1 9 36 84 126 126 84 36 9 1