赞
踩
执行效果如下:
请输入一个整数数字:
50
生成的新数组是:12 14 23 45 50 66 68 70 77 90 91
定义原数组arr,和一个比原数组长度大1的新数组brr。
通过键盘录入的方式输入变量num的值。
定义变量index用于记录num存放的索引位置。
遍历数组,小于或等于num的元素直接存放到原来的位置,大于num的元素往后移动一个位置。
存放结束之后,中间会空出一个位置,在遍历时用index记录这个位置。把num放在这个索引处。
最终遍历新数组打印结果。
- public class Demo6 {
- public static void main(String[] args) {
- //1.定义长度为10的原数组
- int[] arr = {12,14,23,45,66,68,70,77,90,91};
- //2.定义长度为11的空数组
- int[] brr = new int[11];
- //3.键盘录入数组
- Scanner sc = new Scanner(System.in);
- System.out.println("请输入一个整数数字");
- int num = sc.nextInt();
- //4.定义变量代表要插入的位置
- int index = 0;
- //5.循环遍历原数组
- for (int i = 0; i < arr.length; i++) {
- if(arr[i] <= num) {
- //5.1如果元素小于等于要插入的数字,则直接存放
- brr[i] = arr[i];
- //5.2把i后面的位置记录下来
- index = i + 1;
- }else{
- //5.3如果元素大于要插入的数字,则往后一个位置存放
- brr[i+1] = arr[i];
- }
- }
- //6.index存储的就是要插入的位置
- brr[index] = num;
- //7.遍历新数组查看结果
- System.out.print("生成的新数组是:");
- for (int i = 0; i < brr.length; i++) {
- System.out.print(brr[i] + " ");
- }
- }
- }
这个题让我比较不好理解的是:index移到i后面一位的那里
可以这样理解,brr[i]前面已经存入小于num的值了,个大于num则brr[i+1]存取arr[i],中间空出的用index记录
还有就是index的初始化为什么为0
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。