失眠网,内容丰富有趣,生活中的好帮手!
失眠网 > 将数组升序排列后 插入一个数 仍然保持升序排列。

将数组升序排列后 插入一个数 仍然保持升序排列。

时间:2023-07-22 05:03:49

相关推荐

将数组升序排列后 插入一个数 仍然保持升序排列。

将数组升序排列后,插入一个数,仍然保持升序排列。

先进性逆序排序

```java`

public static void main(String[] args) {

Scanner input = new Scanner(System.in);

int[] scores = new int[]{99,85,82,63,60};

int i,j;

//定义一个临时变量,将数组中第一个数赋给这个临时变量int min =scores[0];//利用循环,通过冒泡排序将大的数不断置换到数组后面,小的数置换到数组前面for(i=0; i<scores.length; i++){for(j=i+1; j<scores.length; j++){if(scores[i]>scores[j]){min = scores[j];scores[j] = scores[i];scores[i] = min;}}}//定义一个新数组,通过循环把老的数组里的数复制到新数组里int[] newScores = new int[6];for(i=0; i<scores.length; i++){newScores[i] = scores[i];}//定义一个布尔值,作为标记boolean a = false;//数组下标int index = 0;System.out.println("请输入一个正整数:");int num = input.nextInt();//利用循环将插入的数与数组中的数进行比较for(i=0; i<newScores.length-1; i++){//当遇到数组中的数比这个数大时,记下此时数组中的数的下标,并且break.跳出循环if(num<newScores[i]){index = i;break;}//当这个数比数组中所有的数都大时,将这个点标记为true,并将数组中最后一个下标索引赋予indexwhile(num>=newScores[newScores.length-2]){a = true;index = newScores.length-1;break;}}//当a为false时,用循环将插入位置的数及之后的数逐个向后移动一位(必须从最后一个数开始移动)if(a==false){for(i=newScores.length-1; i>index; i--){newScores[i] = newScores[i-1];}数移动完之后再将这个数插入到已标记好的位置newScores[index] = num;//当a为true时,只需把数插入到数组的最后一位}else{newScores[index] = num;}//循环输出for(i=0; i<newScores.length; i++){System.out.print(newScores[i]);}

}

如果觉得《将数组升序排列后 插入一个数 仍然保持升序排列。》对你有帮助,请点赞、收藏,并留下你的观点哦!

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。