package cn.tx; //组个最小数
import java.util.Scanner;
public class Demo1 {
public static boolean obj(int[] arr){//bool为true表示数组不含0,否则含0
boolean bool = true;
for (int i = 0; i < arr.length; i++) {
if(arr[i] == 0){
bool = false;
break;
}
}
return bool;
}
public int[] swap(int[] arr) {//数组不含0
for (int i = 0; i < arr.length - 1; i++) {
for (int j = 0; j < arr.length - i - 1; j++) {
if (arr[j] > arr[j + 1]) {
int cnt = arr[j];
arr[j] = arr[j + 1];
arr[j + 1] = cnt;
}
}
}
return arr;
}
public static void main(String[] args) {//定义一个数组,输入数组元素的值。如果数组长度大于10,且小于等于50,
int[] arr = new int[10];
Scanner in = new Scanner(System.in);
int sum = 0;
for (int i = 0; i < arr.length; i++) {
arr[i] = in.nextInt();
sum+=arr[i];
}
Demo1 demo = new Demo1();
if (sum>=1){
//判断数组元素是否含0,若不为0,则进行排序;若为0,考虑数字第一位不能为0
if (obj(arr)) {
int[] arr1=demo.swap(arr);
for (int i = 0; i < arr1.length; i++) {
System.out.print(arr1[i]);
}
}
else{
int[] arr2=demo.swap(arr);
for (int i = 0; i < arr2.length; i++) {
if(arr2[i]!=0){
int ar=arr2[i];
arr2[i]=arr2[0];
arr2[0]=ar;
break;
}
}
for (int i = 0; i < arr2.length; i++) {
System.out.print(arr2[i]);
}
}
}
}
}
当数组长度为10,可运行,数组的长度在(<=50)区间变动,怎么解决,求解!