java实现华为之老师想知道从某某同学当中,分数最高的是多少,现在请你编程模拟老师的询问。当然,老师有时候需要更新某位同学的成绩.
2017-06-11 16:52
1776 查看
import java.util.ArrayList; import java.util.Scanner; /** * 老师想知道从某某同学当中,分数最高的是多少,现在请你编程模拟老师的询问。当然,老师有时候需要更新某位同学的成绩. * 输入包括多组测试数据。 *每组输入第一行是两个正整数N和M(0 < N <= 30000,0 < M < 5000),分别代表学生的数目和操作的数目。 *学生ID编号从1编到N。 *第二行包含N个整数,代表这N个学生的初始成绩,其中第i个数代表ID为i的学生的成绩 *接下来又M行,每一行有一个字符C(只取‘Q’或‘U’),和两个正整数A,B,当C为'Q'的时候, 表示这是一条询问操作,他询问ID从A到B(包括A,B)的学生当中,成绩最高的是多少 *当C为‘U’的时候,表示这是一条更新操作,要求把ID为A的学生的成绩更改为B。 *对于每一次询问操作,在一行里面输出最高成绩. * @author pomay * */ public class Main { public static void main(String[] args) { Scanner sc = new Scanner(System.in); do { int[] data = new int[2]; data[0] = sc.nextInt(); data[1] = sc.nextInt(); ArrayList<Integer> array = new ArrayList<Integer>(); // 将成绩存入动态数组中 for (int i = 0; i < data[0]; i++) { array.add(sc.nextInt()); } int round = 0; char a; int b, c; while (round < data[1]) { a = sc.next().charAt(0); b = sc.nextInt(); c = sc.nextInt(); if (a == 'Q') { int start, end; if (b < c) { start = b - 1; end = c - 1; } else { start = c - 1; end = b - 1; } int max = array.get(start); // 获得第一个查询的学生成绩 for (int index = start + 1; index <= end; index++) { if (max < array.get(index)) { max = array.get(index); } } System.out.println(+max); max = 0; } if (a == 'U') { int index1 = b - 1; int newValue = c; array.set(index1, newValue); } round++; } } while (sc.hasNext()); sc.close(); } }
相关文章推荐
- 【java-算法】【华为真题】老师想知道从某某同学当中,分数最高的是多少,现在请你编程模拟老师的询问。当然,老师有时候需要更新某位同学的成绩.
- 【华为上机试题C++】老师想知道从某某同学当中,分数最高的是多少,现在请你编程模拟老师的询问。当然,老师有时候需要更新某位同学的成绩.
- 【华为上机试题C++】老师想知道从某某同学当中,分数最高的是多少,现在请你编程模拟老师的询问。当然,老师有时候需要更新某位同学的成绩.
- 老师想知道从某某同学当中,分数最高的是多少,现在请你编程模拟老师的询问。当然,老师有时候需要更新某位同学的成绩.
- 老师想知道从某某同学当中,分数最高的是多少,现在请你编程模拟老师的询问。当然,老师有时候需要更新某位同学的成绩
- 老师想知道从某某同学当中,分数最高的是多少,现在请你编程模拟老师的询问。当然,老师有时候需要更新某位同学的成绩.
- 老师想知道从某某同学当中,分数最高的是多少,现在请你编程模拟老师的询问。当然,老师有时候需要更新某位同学的成绩.
- 老师想知道从某某同学当中,分数最高的是多少,现在请你编程模拟老师的询问。当然,老师有时候需要更新某位同学的成绩. 输入描述:
- 每门课由平时成绩和考试成绩组成,满分为r。现在他知道每门课的平时成绩为ai ,若想让这门课的考试成绩多拿一分的话,小v要花bi 的时间复习,不复习的话当然就是0分。同时我们显然可以发现复习得再多也不会拿到超过满分的分数。为了拿到奖学金,小v至少要花多少时间复习。
- [java面试]逻辑推理6 10 18 32 下一个数?编程实现输入任意一个N位置,该数是多少?java实现
- java语言编程实现两个时间相差多少天、多少小时、多少分、多少秒
- 【Codeforces Beta Round 2A】【模拟 map 有map的java实现哦】Winner 第一个达到最终最高分的人名
- java-编程实现两个正整数的除法,当然不能用除法操作符
- java网络编程一:模拟qq聊天功能,实现一对一聊天
- java编程如何实现多条2017-08-08 22:10:00.0这样的时间数据,相差多少天?(隔24小时为相差1天,否则为0天)
- 编程实现:每瓶汽水1元,两个空瓶可以置换一瓶汽水,现在有20元,最多能喝多少瓶汽水
- [java面试]逻辑推理6 10 18 32 下一个数?编程实现输入任意一个N位置,该数是多少?java实现
- java中字符串处理、串联和转换的几个常用方法,以及如果需要自己编程实现的具体实施步骤。
- 你会不会喜欢编程多一点之当我特别想知道jdk1.8.0_20中有多少.java的文件时
- 五十道编程小题目 --- 50 有五个学生,每个学生有3门课的成绩,计算出平均成绩,况原有的数据和计算出的平均分数存放在磁盘文件"stud"中java