用java编程,,选择排序问题,菜单包括:升序排序,降序排序.输入n个整数,对其进行排序(n由键

)... 展开
 我来答
liuyang054
2015-05-13 · TA获得超过9093个赞
知道大有可为答主
回答量:5317
采纳率:78%
帮助的人:5303万
展开全部
import java.util.Scanner;

public class Test {
public static int cd(){
int i ;
System.out.println("*********************");
System.out.println("*******选择排序******");
System.out.println("***** 1   升序*******");
System.out.println("***** 2   降序*******");
System.out.println("***** 0   退出*******");
System.out.println("*********************");
Scanner sc = new Scanner(System.in);
System.out.print("请输入你的选择:");
i = sc.nextInt();
return i;
}

public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
System.out.println("输入n:");
int n = sc.nextInt();
int[] a = new int[n];
for(int i = 0; i < n; i++){
System.out.print("输入第[ " + (i + 1) +" ]个数 : ");
a[i] = sc.nextInt();
}
int i ;
i = cd();
while(i != 0){
switch (i) {
case 1:
for (i = 0; i < a.length - 1; i++) {
int min = i;
for (int j = i + 1; j < a.length; j++) {
if (a[min] > a[j]) {
min = j;
}
}
if (min != i) {
int temp = a[i];
a[i] = a[min];
a[min] = temp;
}
}
System.out.println("升序排序后的结果 : ");
for(int temp : a){
System.out.print(temp + " ");
}
System.out.println();
break;
case 2:
for (i = 0; i < a.length - 1; i++) {
int min = i;
for (int j = i + 1; j < a.length; j++) {
if (a[min] < a[j]) {
min = j;
}
}
if (min != i) {
int temp = a[i];
a[i] = a[min];
a[min] = temp;
}
}
System.out.println("降序排序后的结果 : ");
for(int temp : a){
System.out.print(temp + " ");
}
System.out.println();
break;
case 0:
System.out.println("exit!");
break;
}
i = cd();
}
}
}

推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式