日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問(wèn) 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 编程资源 > 编程问答 >内容正文

编程问答

java如何在一个有序的数组类插入一个数!

發(fā)布時(shí)間:2024/4/17 编程问答 20 豆豆
生活随笔 收集整理的這篇文章主要介紹了 java如何在一个有序的数组类插入一个数! 小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

?

第一種:依次與有序數(shù)組中的每個(gè)數(shù)進(jìn)行比較,然后找到位置之后,定義一個(gè)新的數(shù)組,該信數(shù)組的長(zhǎng)度加一,再使用system.arraycopy將于數(shù)組copy到新數(shù)組!import java.util.Arrays;

import java.util.Scanner;public class Sort {public static void main(String[] args) {Scanner in = new Scanner(System.in);int nums[] = new int[10];System.out.println("請(qǐng)輸入一組數(shù)字(不超過(guò)10個(gè)數(shù)字):");for(int i =0 ;i<nums.length;i++){int j = in.nextInt();nums[i]=j;}bubblesort(nums);Output(nums);System.out.println("請(qǐng)從鍵盤(pán)輸入一個(gè)數(shù)!");int a = in.nextInt();nums=insert(a,nums);System.out.println("插入數(shù)字之后的排序?yàn)?#xff1a;");Output(nums); } public static void bubblesort(int [] nums) {//對(duì)數(shù)組進(jìn)行冒泡排序for(int i =0;i<nums.length-1;i++){for(int j=0;j<nums.length-1-i;j++){if(nums[j]>nums[j+1]){int temp = nums[j];nums[j] =nums[j+1];nums[j+1]=temp;}}}
}public static int[] insert(int a,int [] nums){//進(jìn)行插入操作int index = 0;for(int i = 0;i<nums.length;++i){if(a>=nums[i]){index++;}}int[] newArray = new int[nums.length + 1]; newArray[index] = a ;System.arraycopy(nums, 0, newArray, 0 , index );System.arraycopy(nums, index, newArray, index + 1 , nums.length - index);return newArray ; //返回新數(shù)組 } public static void Output(int [] nums){for(int j = 0;j<nums.length;j++){System.out.print(nums[j]+" ");}System.out.println();}}

  

第二種方法:只是查找時(shí)略有不同,是用的是二分查找的思想:

import java.util.Arrays;public class BinaryInsert {public static void main(String[] args) {BinaryInsert bt = new BinaryInsert();int[] array = new int[]{1 , 3 , 6 , 8, 30 , 49 , 60 , 70 , 83 , 85};System.out.println(Arrays.toString(array));array = bt.insert(array , 50);System.out.println(Arrays.toString(array));}public int[] insert(int[] sortArray , int value){int index = findInsertIndex(sortArray , value , 0 , sortArray.length); //找到插入位置int[] newArray = new int[sortArray.length + 1]; newArray[index] = value ;System.arraycopy(sortArray, 0, newArray, 0 , index );System.arraycopy(sortArray, index, newArray, index + 1 , sortArray.length - index);return newArray ; //返回新數(shù)組}//找到value適合插入的位置public int findInsertIndex(int[] sortArray , int value , int left , int right){int middleIndex = (right - left) / 2 + left ;int middleValue = sortArray[middleIndex] ; if(right - left < 2){if(value > sortArray[right -1 ])return right;else if(value > sortArray[left]){return left + 1;}else{return left;}}else if(middleValue < value){return findInsertIndex(sortArray , value , middleIndex + 1 , right);}else if(middleValue > value){return findInsertIndex(sortArray , value , left , middleIndex );}else{return middleIndex + 1;}}}

  注意與順序表中個(gè)的插入數(shù)組進(jìn)行區(qū)別,因?yàn)閿?shù)組的長(zhǎng)度是固定的,無(wú)法像順序表那樣依次移動(dòng)元素進(jìn)行操作!否則會(huì)產(chǎn)生數(shù)組越界錯(cuò)誤!

轉(zhuǎn)載于:https://www.cnblogs.com/jiutiankunpeng/p/5386333.html

總結(jié)

以上是生活随笔為你收集整理的java如何在一个有序的数组类插入一个数!的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。

如果覺(jué)得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。