二维数组练习

练习一

已知有个升序的数组,要求插入一个元素,该数组顺序依然是升序 例如:
{10,12,45,90}插入23后数组为{10,12,23,45,90}
分析:完成思路 定位插入的位置 和数组扩容
完成思路:
1.首先遍历数组使用变量记录插入的元素,依次对比数组中的元素,若<=当前对比元素则记录下当前下标(需要将插入元素比任何元素都大考虑进去)
2.遍历找出插入的下标后,使用IF语句和两个循环变量分别记录新数组与旧数组的下标,当循环到需插入下标后进行赋值
代码实现

//第一步:创建升序数组,定义需要插入的
		int [] arr = {10,12,45,90};
		int intnum=23;
		int index=-1;
		//第二步:找出插入的下标位置且创建新数组
		int [] arrnew=new int[arr.length+1];
		for (int i =0 ;i<arr.length ; i++) {
			//2.1找出要插入的下标
			if (intnum<=arr[i]) {
				index=i;
				break;//找到下标后就退出对比
			}
		}
			//2.2判断是否要插入的元素比任何数都大
			if (index==-1) {
				index=arr.length;
			}


			//第三步:将原数组依次赋值给新数组
			//3.1 i代表新数组的下标
			//3.2 j代表原数组的下标所以当循环到需要插入的位置时不自增
			for (int i =0,j=0;i<=arr.length ;i++ ) {//注意下标问题要多循环一次
				if (i!=index) {//依次赋值除了该插入时
				arrnew[i]=arr[j];
				j++;
			}else{//当轮到要插入的下标时
				arrnew[i]=intnum;
			}
			}
		
		//第四步:将原数组指向新数组,回收掉原数组
		arr=arrnew;
		//输出新数组看效果
		for (int a :arrnew ) {
			System.out.print(a+" ");
		}

练习二

写出冒泡排序
重点:外层for循环记录对比的轮数,内层循环进行遍历,然后语句块操作换位,内层循环中-i是因为每轮对比会比较出一个极端的数没必要再对比一遍,-1是因为下方语句块中使用的是j+1的方式操作后面一个下标,不减去会数组下标异常

//冒泡排序
		int [] arr={56,34,23,76,3};
		int index=0;
		for (int i=0;i<arr.length-1 ;i++ ) {
			for (int j =0;j<arr.length-1-i ;j++ ) {
				if (arr[j]>arr[j+1]) {
					index=arr[j+1];
					arr[j+1]=arr[j];
					arr[j]=index;
				}
			}
		}
		for (int a :arr ) {
			System.out.print(a+" ");
		}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值