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

这里有题目和答案给具体解释一下,尤其是一行后面有问号标注的地方两个版本,或者给我做一个更好理解的。着重解释一下“从中获取重复次数最多并且最大的数”是怎么实现的import... 这里有题目和答案 给具体解释一下,尤其是一行后面有问号标注的地方 两个版本,或者给我做一个更好理解的。着重解释一下“从中获取重复次数最多并且最大的数”是怎么实现的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+"次"); }} 展开
 我来答
baifeiyangdu
2013-11-27 · TA获得超过203个赞
知道答主
回答量:125
采纳率:0%
帮助的人:77.6万
展开全部

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 + "次");


思路:

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

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

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

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

描述的不好,请见谅

yiliuking
2013-11-27 · TA获得超过195个赞
知道小有建树答主
回答量:183
采纳率:100%
帮助的人:94万
展开全部
第一个程序的思路大概是这样:设置两个数组,第一个数组用来存放生成的随机数,第二个数组用来存放每个随机数出现的次数。
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次

看的头晕死了,代码还有问题
本回答被提问者和网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
cs903016
2013-11-26 · TA获得超过1179个赞
知道小有建树答主
回答量:2599
采纳率:80%
帮助的人:1708万
展开全部
头好疼啊!楼主这是什么排版!
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 1条折叠回答
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式