西安工业大学是国家二级保密单位,常常接到一些军方保密项目。但是保密的项目要求很严格。1.不能使用自己的计算机,需要使用特配的。2.计算机不能接入互联网。3.代码的合并以及转移不能通过U盘,只能通过特定的光盘。4.代码的格式也有严格要求。
以下为某次保密项目部分代码要求:
小明完成了任务,但不知道自己的代码是否符合规范。你只需要帮他在这里判断重名最多的变量名称和它重复的次数。
输入格式:
第一行给出一个整数N(1<=n<=10),接下来N行,每行给出一行字符串S(长度<100)。所有样例保证出现最多的变量名称唯一,且程序语句无错误(类型名称 变量名称 = 值)。但是在语句正确的情况下不保证无多余空格。每一行仅包含一个语句。定义不包含const等修饰符。
输出格式:
程序结束后你需要输出重名最多的变量名称和它重复了多少次。
输入样例:
5
int a = 2;
int b = 3;
double k = 5.625;
char a = 'a';
float a = 1.567;
输出样例:
a 3
tips:变量名为每一行第二个单词
思路:
题目讲了一大堆,简单来说就是计算第二个单词的出现次数,找到出现次数最多的就行。
一行字符串由空格隔开的单词组成,为了得到单词数组,最简单的方法就是使用Java的split函数,得到String[]对象。
参考代码:
import java.util.*;
public class Main {
public static void main(String[] args) {
Scanner in = new Scanner(System.in);
int n = in.nextInt();
Map<String, Integer> count = new HashMap<>();
in.nextLine();
while(n-- > 0) {
String line = in.nextLine();
line = line.replaceAll(" +", " "); // 将多个空格替换成一个空格
if(line.startsWith(" ")) { // 如果替换后的字符串是以空格开头,需要去掉开头的空格
line = line.substring(1);
}
String[] words = line.split(" ");
count.put(words[1], count.getOrDefault(words[1], 0) + 1);
}
String maxStr = null;
Integer maxCount = 0;
for(Map.Entry<String, Integer> entry:count.entrySet()) {
if(entry.getValue() > maxCount) {
maxCount = entry.getValue();
maxStr = entry.getKey();
}
}
System.out.println(maxStr + " " + maxCount);
}
}