java题目:将1到100中的100个自然数随机的放到一个数组,从中获取重复次数最多并且最大的数,显示出来。

这里有题目和答案 给具体解释一下,尤其是一行后面有问号标注的地方 两个版本,或者给我做一个更好理解的。着重解释一下“从中获取重复次数最多并且最大的数”是怎么实现的import java.util.Random;public class Test { public static void main(String[] args) { // TODO Auto-generated method stub int [] figures = new int [100]; int [] times = new int [100]; int time = 0; int figure = 0; Random random = new Random(); for(int i =0;i<figures.length;i++){ figures[i] = random.nextInt(100); times[figures[i]] ++; ———————— ???这个式子的运算过程 还有它是什么意思 System.out.print(figures[i] + ","); } for(int i=0;itime){ ——————————??? time = times[i]; figure = i; } } System.out.println(); System.out.println("重复最多的数字是" + figure); System.out.println("重复次数是" + time); }}************************************************************************************************************public class TestRandom { public static void main(String[] args) { int[] a = new int[100]; for(int i=1;i<=100;i++){ int temp = (int)(Math.random()()*100)+1; ???为什么要加1 System.out.print(temp+" "); a[temp-1]++; ——————————————— ???这个式子的运算过程 还有它是什么意思 } System.out.println(); int t = 0; int k = 0; for(int i = 0;i<100;i++){>=t){ —————————————————— ??? t = a[i]; k=i; } } System.out.println("出现最大且最多的数字是"+(k+1)); System.out.println("它出现了"+t+"次"); }}

int size = 10;

int[] figures = new int[size];

int[] times = new int[size];

Random random = new Random();

for (int i = 0; i < figures.length; i++) {

figures[i] = random.nextInt(size) + 1;//产生1-size中的数字

System.out.print(figures[i] + ",");

}

System.out.println("\n升序排序后");

Arrays.sort(figures);

int num = figures[0];//取出升序后的第一个元素与之后的元素进行比较

System.out.print(figures[0] + ",");

int cishu = 1;

for (int i = 1; i < figures.length; i++) {

System.out.print(figures[i] + ",");

if (num == figures[i]) {

cishu++;

times[figures[i] - 1] = cishu;//设置该元素的下表和出现的次数

} else {

cishu = 1;

}

num = figures[i];


}

System.out.println();

cishu = times[0];

num = 0;

for (int i = 1; i < times.length; i++) {

if (cishu <= times[i]) {

cishu = times[i];

num = i;

}


}

System.out.println((num + 1) + "出现次数最多" + cishu + "次");


思路:

    循环size个1到size之间(包括1和size)的数字保存在数组中

    使用Arrays.sort()函数 使数组升序排序

    依次比较大小,并将数字作为下标(数字-1),出现次数作为值存到另一数组中,

    将另一数组中最大值(次数)输出,下标+1即为数字

描述的不好,请见谅

温馨提示:答案为网友推荐,仅供参考
第1个回答  2013-11-27
第一个程序的思路大概是这样:设置两个数组,第一个数组用来存放生成的随机数,第二个数组用来存放每个随机数出现的次数。
figures[i] = random.nextInt(100);//生成随机数
times[figures[i]] ++; //增加随机数出现的次数。
这里实际上利用了数组的长度,假设100个随机数都是50,代码就成了
figures[i] = 50;
(times[figures[i]] = times[50])
times[50]++;
到最后结果是figures数组里的数字全是50,times数组里第50个(实际上是第51个,数组下标从0开始)数的值为100,也就是说50这个数字出现了100次

看的头晕死了,代码还有问题本回答被提问者和网友采纳
第2个回答  2013-11-26
头好疼啊!楼主这是什么排版!
相似回答