把一个数字插入已排序的数组,插入后的数组依旧按原规则排序

思路:

1.先确定数组的排序规则

2. 查找待插入数字需要插入的准确位置(需要遍历数组)

3. 返回一个新的数组

 

public static int[] insertArray(int[] target ,int insertNum){
int[] tar=new int[target.length+1];
//升序排列
int index=0;
if(target[0]<target[target.length-1]){
for(int i=0;i<target.length-2;i++){
if(insertNum>=target[i] && insertNum<=target[i+1]){
index = i+1;
break;
}
}
}

//降序

else if(target[0]>target[target.length-1]){
for(int i=0;i<target.length-2;i++){
if(insertNum<=target[i] && insertNum>=target[i+1]){
index = i+1;
break;
}
}
}
else {
index = 0;
}
System.arraycopy(target, 0, tar, 0, index);
tar[index] = insertNum;
System.arraycopy(target, index, tar, index+1, tar.length-index-1);
return tar;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值