用java代码实现编写子函数:(1)用冒泡法将一个数组排成升序的函数---SUB1;(2)在升序数组中插入一个
答案:2 悬赏:60 手机版
解决时间 2021-03-16 22:33
- 提问者网友:骑士
- 2021-03-16 16:00
用java代码实现编写子函数:(1)用冒泡法将一个数组排成升序的函数---SUB1;(2)在升序数组中插入一个
最佳答案
- 五星知识达人网友:三千妖杀
- 2021-03-16 17:13
public class HandleArray {
public static void main(String[] args) {
HandleArray handleArray = new HandleArray();
int[] arr = new int[]{19,4,3,7,2,5,4};
arr = handleArray.orderArrayAsc(arr);
for (int i = 0; i < arr.length; i++) {
System.out.print(arr[i]+" ");
}
System.out.println();
arr = handleArray.insertIntoAscArray(arr,20);
for (int i = 0; i < arr.length; i++) {
System.out.print(arr[i]+" ");
}
}
//数组升序排列函数
public int[] orderArrayAsc(int[] array){
for (int i = 0; i < array.length-1; i++) {
for (int j = i+1; j < array.length; j++) {
if(array[i]>array[j]){
int tmp = array[i];
array[i] = array[j];
array[j] = tmp;
}
}
}
return array;
}
//在升序数组中插入一个数值函数
public int[] insertIntoAscArray(int[] array,int val){
int[] tmpArray = new int[array.length+1];
int n = 0;
//当前数比数组中的所有数都大
if(array[array.length-1]
n = array.length;
}else{
//比较大小,找出该数值应该在数组中的位置
for (int i = 0; i < array.length; i++) {
if(array[i]>=val){
n = i;
break;
}
}
}
System.arraycopy(array, 0, tmpArray, 0, n);
tmpArray[n] = val;
System.arraycopy(array, n, tmpArray, n+1, array.length-n);
return tmpArray;
}
}
public static void main(String[] args) {
HandleArray handleArray = new HandleArray();
int[] arr = new int[]{19,4,3,7,2,5,4};
arr = handleArray.orderArrayAsc(arr);
for (int i = 0; i < arr.length; i++) {
System.out.print(arr[i]+" ");
}
System.out.println();
arr = handleArray.insertIntoAscArray(arr,20);
for (int i = 0; i < arr.length; i++) {
System.out.print(arr[i]+" ");
}
}
//数组升序排列函数
public int[] orderArrayAsc(int[] array){
for (int i = 0; i < array.length-1; i++) {
for (int j = i+1; j < array.length; j++) {
if(array[i]>array[j]){
int tmp = array[i];
array[i] = array[j];
array[j] = tmp;
}
}
}
return array;
}
//在升序数组中插入一个数值函数
public int[] insertIntoAscArray(int[] array,int val){
int[] tmpArray = new int[array.length+1];
int n = 0;
//当前数比数组中的所有数都大
if(array[array.length-1]
}else{
//比较大小,找出该数值应该在数组中的位置
for (int i = 0; i < array.length; i++) {
if(array[i]>=val){
n = i;
break;
}
}
}
System.arraycopy(array, 0, tmpArray, 0, n);
tmpArray[n] = val;
System.arraycopy(array, n, tmpArray, n+1, array.length-n);
return tmpArray;
}
}
全部回答
- 1楼网友:慢性怪人
- 2021-03-16 18:10
你说呢...
我要举报
如以上问答信息为低俗、色情、不良、暴力、侵权、涉及违法等信息,可以点下面链接进行举报!
大家都在看
推荐资讯