有一个已经排好序的数组。现输入一个数,要求按原来的规律将它插入数组中。
2020-08-31 · 百度认证:云南新华电脑职业培训学校官方账号
云南新华电脑学校
云南新华电脑学校是经云南省教育厅批准成立的省(部)级重点计算机专业学校,采用三元化管理模式,教学设备先进,师资雄厚学生毕业即就业,学院引进了电商企业入驻,创建心为电商创业园区,实现在校即创业
向TA提问
关注
展开全部
import java.util.Scanner;
public class Prog30{
public static void main(String[] args){
int[] A = new int[]{0,8,7,5,9,1,2,4,3,12};
int[] B = sort(A);
print(B);
System.out.println();
System.out.print(" 请输入 10 个数的数组: ");
Scanner scan = new Scanner(System.in);
int a = scan.nextInt();
scan.close();
int[] C = insert(a,B);
print(C);
}
// 选择排序
private static int[] sort(int[] A){
int[] B = new int[A.length];
for(int i=0;i<A.length-1;i++){
int min = A[i];
for(int j=i+1;j<A.length;j++){
if(min>A[j]){
int temp = min;
min = A[j];
A[j] = temp;
}
B[i] = min;
}
}
B[A.length-1] = A[A.length-1];
return B;
}
// 打印
private static void print(int[] A){
for(int i=0;i<A.length;i++)
System.out.print(A[i]+" ");
}
// 插入数字
private static int[] insert(int a,int[] A){
int[] B = new int[A.length+1];
for(int i=A.length-1;i>0;i--)
if(a>A[i]){
B[i+1] = a;
for(int j=0;j<=i;j++)
B[j] = A[j];
for(int k=i+2;k<B.length;k++)
B[k] = A[k-1];
break;
}
return B;
}
}
public class Prog30{
public static void main(String[] args){
int[] A = new int[]{0,8,7,5,9,1,2,4,3,12};
int[] B = sort(A);
print(B);
System.out.println();
System.out.print(" 请输入 10 个数的数组: ");
Scanner scan = new Scanner(System.in);
int a = scan.nextInt();
scan.close();
int[] C = insert(a,B);
print(C);
}
// 选择排序
private static int[] sort(int[] A){
int[] B = new int[A.length];
for(int i=0;i<A.length-1;i++){
int min = A[i];
for(int j=i+1;j<A.length;j++){
if(min>A[j]){
int temp = min;
min = A[j];
A[j] = temp;
}
B[i] = min;
}
}
B[A.length-1] = A[A.length-1];
return B;
}
// 打印
private static void print(int[] A){
for(int i=0;i<A.length;i++)
System.out.print(A[i]+" ");
}
// 插入数字
private static int[] insert(int a,int[] A){
int[] B = new int[A.length+1];
for(int i=A.length-1;i>0;i--)
if(a>A[i]){
B[i+1] = a;
for(int j=0;j<=i;j++)
B[j] = A[j];
for(int k=i+2;k<B.length;k++)
B[k] = A[k-1];
break;
}
return B;
}
}
展开全部
//用优先级队列就行了。
#include<cstdio>
#include<queue>
using namespace std;
priority_queue<int,vector<int>,less<int> >que;//如果要从大到小,把less改成greater
main(){
int n;
printf("请输入数组元素个数:");
scanf("%d",&n);
printf("\n请输入数组元素:");
int x;
for(int i=0;i<n;i++){
scanf("%d",&x);
que.push(x);
}
printf("\n输入要插进的数:");
scanf("%d",&x);
que.push(x);
while(!que.empty()){
printf("%d ",que.top());
que.pop();
}
return 0;
}
//请采纳
#include<cstdio>
#include<queue>
using namespace std;
priority_queue<int,vector<int>,less<int> >que;//如果要从大到小,把less改成greater
main(){
int n;
printf("请输入数组元素个数:");
scanf("%d",&n);
printf("\n请输入数组元素:");
int x;
for(int i=0;i<n;i++){
scanf("%d",&x);
que.push(x);
}
printf("\n输入要插进的数:");
scanf("%d",&x);
que.push(x);
while(!que.empty()){
printf("%d ",que.top());
que.pop();
}
return 0;
}
//请采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
用插入排序算法
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询