一道Java的题目 求编程

ProblemDescription:Writeaprogramthatreadsintegers,findsthelargestofthem,andcountsitso... Problem Description:
Write a program that reads integers, findsthe largest of them, and counts its occurrences. Assume that the input endswith number 0. Suppose that you entered 3 5 2 5 5 5 0; the program finds thatthe largest is 5 and the occurrence count for 5 is 4. (Hint: Maintain twovariables, max and count. max stores the current max number, and count storesits occurrences. Initially, assign the first number to max and 1 to count.Compare each subsequent number with max. If the number is greater than max,assign it to max and reset count to 1. If the number is equal to max, incrementcount by 1.)

Here are sample runs of the program:

Sample 1:
Enternumbers: 3 5 2 5 5 5 0
Thelargest number is 5
Theoccurrence count of the largest number is 4

Sample 2:
Enternumbers: 3 6 5 4 2 4 5 4 55 0
Thelargest number is 6
Theoccurrence count of the largest number is 1
展开
 我来答
Ethan666888
2014-02-14 · TA获得超过1万个赞
知道小有建树答主
回答量:950
采纳率:50%
帮助的人:401万
展开全部

首先你读懂谨稿题没有,我帮你翻译一下:


问题描述: 

编写一个程序,读取整尺侍数,找出其中最大的,并计算其出现次数。假设输入与数字0结束。假设你进入3 5 2 5 5 5 0;程序发现,最大的为5,出现次数为4. (提示:建立两个变量,最大值和计数值,最大存储当前的最大数量,并计算其出现次数,分配一个最大值和1来计算比较每个后续数,最大如果人祥困孝数大于最大。 ,将其分配到最大,并重置计数为1,如果数等于最大,由1递增计数。) 


下面是该程序的运行示例: 

 

示例1: 

输入数字:3 5 2 5 5 5 0 

最大数量为5 

出现次数为4 

 

示例2: 

输入数字:3 6 5 4 2 4 5 4 5 5 0  

最大数是6 

出现次数为1


简单的说,问题就是随便输入一串数字,找出最大值,并且计算其出现次数!

问题搞清楚了,就来编程吧,经测试,我的代码可以正确运行:


package test01;


import java.util.Scanner;


public class TestSystemIn {

public static void main(String[] args) {

System.out.println("请输入内容,不同内容以逗号隔开,请以0结尾,以回车结束");

Scanner scanner = new Scanner(System.in);

String str = scanner.next();

String a[] = str.split(",");

int temp = 0;

if (0 != (Integer.parseInt(a[a.length - 1]))) {

System.out.println("请以0结尾");

return;

}

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

if (Integer.parseInt(a[i]) > temp) {

temp = Integer.parseInt(a[i]);

}

}

System.out.println("最大的为:" + temp);

int max = temp;

int times = 0;

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

if (Integer.parseInt(a[i]) == max) {

times++;

}

}

System.out.println("出现的次数为:" + times);

}

}


woaihouzhuang
2014-02-14 · TA获得超过259个赞
知道小有建树答主
回答量:245
采纳率:100%
帮助的人:226万
展开全部

给出代码如下:

//get the max and occurance
public static void getMax() throws IOException {
BufferedReader reader = new BufferedReader(new InputStreamReader(System.in));
String input = reader.readLine();
if(input == null || 仿洞input.trim().length() == 0){
System.out.println("your 银睁input occurs error!");
return ;
}
String[] arr = input.split(" ");
if(!arr[arr.length-1].trim().equals("0")) {
System.out.println("your input occurs error!");
return ;
}
int max = Integer.valueOf(arr[0]), occur = 1;
for(int i = 1, length = arr.length-1 ;i < length;i ++) {
if(Integer.valueOf(arr[i]) > max) {
max = Integer.valueOf(arr[i]);
occur = 1;
} else if ( Integer.valueOf(arr[i]) == max) {
occur ++;

}
System.out.println("The max num is "+ max 备搏枯+"; and the occurance is "+ occur);
}


调用代码:


public static void main(String[] args) throws ParseException, IOException {
// TODO Auto-generated method stub
getMax();
}

楼主不懂,可以继续追问。

已赞过 已踩过<
你对这个回答的评价是?
评论 收起
arache
2014-02-14 · TA获得超过212个赞
知道小有建树答主
回答量:222
采纳率:0%
帮助的人:169万
展开全部
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;

public class Main {

 如州   static int max = Integer.MIN_VALUE;
    static int countOfMax = 0;

    public static void main(String[] args) throws IOException {
        BufferedReader reader = new BufferedReader(new InputStreamReader(System.in));
        String line;

        while (true) {
            System.out.print("Enter numbers: ");
            line = reader.readLine();
            String[] numbers = line.split(" ");
            if (!"0".equals(numbers[numbers.length-1])) {
                System.err.println("The input has to end with number 0");
           配碧     System.out.println();
                continue;
            }

            int[] numberArray = new int[numbers.length-1];

            for (int i = 0; i < numbers.length-1; i++) {
                numberArray[i] = Integer.parseInt(numbers[i]);
            }

            analyze(numberArray);
            System.out.println("The largest number is " + max);
            System.out.println("The occurrence count of the largest number is " + countOfMax);
            System.out.println();
        }

    }

    public static void analyze(int[] input) {
        渣卖蔽reset();
        for (int num : input) {
            if (num > max) {
                max = num;
                countOfMax = 1;
            }
            else if (num == max) {
                countOfMax++;
            }
        }
    }

    public static void reset() {
        max = Integer.MIN_VALUE;
        countOfMax = 0;
    }
}
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(1)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式