1105學習筆記 陣列的演算法上
1105陣列的演算法
升序
引入一個工具
-
知識
-
如何匯入工具類
- import 工具類的路徑
-
-
例子
- import java.util.Arrays;
使用工具
-
sort方法
-
功能
- 幫我們把陣列進行升序,由小到大
- 會影響陣列內部的結構
-
用法
- Arrays.sort(陣列);
-
參考程式碼
import java.util.Arrays;
public class Test {
public static void main(String[] args) {
int[] nums = new int[]{2,5,3,2,6};
Arrays.sort(nums);
for(int i=0;i<nums.length;i++){
System.out.println(nums[i]);
}
}
}
交換兩個變數
使用第三個變數
-
程式碼
import java.util.Arrays; public class Test { public static void main(String[] args) { int a = 11; int b = 22; int temp; System.out.println("資料交換前a與b的值" + a + "---" + b); // 讓臨時的變數接收一個資料 temp = b; b = a; a = temp; // 資料交換成功 System.out.println("資料交換後a與b的值" + a + "---" + b); } }
-
核心程式碼
temp = b; b = a; a = temp;
不允許使用第三個變數
-
核心程式碼
a=a+b; b=a-b; a=a-b;
逆序
游標移動的最大下標演算法
- 陣列會在哪裡停下,取決於陣列的長度。
- 如果陣列的長度是n,那麼
- 下標不會走到n/2
演算法程式碼
public class Test {
public static void main(String[] args) {
// 初始化一個陣列
String[] strList = {"a", "b", "c", "d", "e", "f", "g", "h", "i", "j", "k"};
// 遍歷時遇到哪個索引會停止的演算法: 陣列的長度除2取整
int topIdx = strList.length / 2;
// 開始遍歷,讓下標從0開始遊走
for (int i = 0; i < topIdx; i++) {
// 把下標所在的值交給臨時變數
String temp = strList[i];
// 獲得交換索引值,計算出要與哪個索引進行資料交換
int changeIndex = strList.length - 1 - i;
// 把交換索引值,對應的資料賦值給當前游標所在空間
strList[i] = strList[changeIndex];
// 把臨時變數的值,賦值給交換索引的值
strList[changeIndex] = temp;
}
// 遍歷陣列,檢視排序後的效果
for (int j = 0; j < strList.length; j++) {
System.out.print(strList[j]);
}
}
}
求最大值
演算法
- 來一個臨時變數
- 讓陣列成員的值與臨時變數比較
- 誰大,就把誰的值賦給臨時變數
程式碼
public class getmaxnum {
public static void main(String[] args) {
// 定義一個整數陣列,同時給與初始值
int[] numList = {11, 22, 4, 3, 55, 33};
// 開始比較大小
// 定義一個變數,用於儲存最大的資料
int temp = numList[0];
// 開始鹿歷
for (int i = 1; i < numList.length; i++) {
// 需要重複的事情就是
// 拿temp的資料與下標所對應的資料進行大小比較,
if (numList[i] > temp) {
// 把當前下標對應的值,賦給temp變數
temp = numList[i];
}
}
System.out.println("最大的值是" + temp);
}
}
追加資料
演算法
- 遍歷陣列找到第一個出現null的位置
- 記錄這個位置,並往陣列的這個位置插入資料
程式碼
String[] strList = new String[5];
// 給空間賦值
strList[0] = "hello";
strList[1] = "java";
strList[2] = "welcom";
// 需要插入的資料
String sendKey = "c#";
// 插入演算法
for (int i = 0; i < strList.length; i++) {
System.out.println(i);
// 每一次進入迴圈要重複做的事情
// 判斷游標i所對應的值是否為null
if (strList[i] == null) {
// System.out.println("游標對應的值是null" + i);
strList[i] = sendKey;
break;
}
}
for (int j = 0; j < strList.length; j++) {
System.out.println(strList[j]);
}
中部插入資料
虛擬碼
第一步:
找到最大有效資料的下標
int temp=0;
for(int m=0;m<陣列.length;m++){
if(陣列[m]==null){
temp = m;
break;
}
temp--;
}
第二步:後移
// 資料後移的遍歷
for(int i=temp;i>j;i--){
陣列[i+1]=陣列[i];
}
第三步:
資料的插入
陣列[j]=“html";
XMind - Trial Version
相關文章
- 字尾陣列 學習筆記陣列筆記
- 字尾陣列學習筆記陣列筆記
- Java學習筆記——陣列練習(七)Java筆記陣列
- Java 學習筆記 二維陣列和物件陣列Java筆記陣列物件
- 【numpy學習筆記】陣列的切片,索引,迭代筆記陣列索引
- 飛機的 PHP 學習筆記五:陣列PHP筆記陣列
- Solidity語言學習筆記————12、陣列Solid筆記陣列
- Perl學習筆記(五)——關聯陣列筆記陣列
- JavaScript 學習筆記 - 多維陣列變為一維陣列JavaScript筆記陣列
- numpy學習筆記 – numpy陣列的常見用法筆記陣列
- Java學習筆記【1】陣列的宣告和建立Java筆記陣列
- JavaScript學習筆記(二)——函式和陣列JavaScript筆記函式陣列
- 【numpy學習筆記】陣列的建立和基本運算筆記陣列
- 【numpy學習筆記】陣列的儲存和下載筆記陣列
- ES6學習筆記(二)【數值,陣列】筆記陣列
- Go 語言學習筆記之陣列與切片Go筆記陣列
- PHP學習筆記6:表示式&多維陣列PHP筆記陣列
- YU_C++演算法學習筆記 · 列舉C++演算法筆記
- 陣列的學習陣列
- Solidity語言學習筆記————13、固定大小位元組陣列Solid筆記陣列
- Solidity語言學習筆記————14、動態位元組陣列Solid筆記陣列
- JS 陣列筆記JS陣列筆記
- GO 筆記-陣列Go筆記陣列
- 陣列筆記1陣列筆記
- Shells命令列學習筆記命令列筆記
- 演算法學習筆記演算法筆記
- Lua 學習筆記(上)筆記
- 【numpy學習筆記】矩陣操作筆記矩陣
- 陣列學習陣列
- IOS筆記之陣列iOS筆記陣列
- 【筆記】字尾陣列筆記陣列
- JavaScript筆記(6)陣列JavaScript筆記陣列
- mysql增加列,刪除列學習筆記MySql筆記
- 機器學習演算法學習筆記機器學習演算法筆記
- Floyd演算法學習筆記演算法筆記
- LMF演算法學習筆記演算法筆記
- 匈牙利演算法學習筆記演算法筆記
- Tarjan 演算法學習筆記演算法筆記