Java-集合练习题1
第一题 (Map)利用Map,完成下面的功能:
从命令行读入一个字符串,表示一个年份,输出该年的世界杯冠军是哪支球队。如果该 年没有举办世界杯,则输出:没有举办世界杯。
附:世界杯冠军以及对应的夺冠年份,请参考本章附录。 附录
- 历届世界杯冠军
届数 |
举办年份 |
举办地点 |
冠军 |
1930年 |
乌拉圭 |
乌拉圭 |
|
第二届 |
1934年 |
意大利 |
意大利 |
第三届 |
1938年 |
法国 |
意大利 |
第四届 |
1950年 |
巴西 |
乌拉圭 |
第五届 |
1954年 |
瑞士 |
西德 |
第六届 |
1958年 |
瑞典 |
巴西 |
第七届 |
1962年 |
智利 |
巴西 |
第八届 |
1966年 |
英格兰 |
英格兰 |
第九届 |
1970年 |
墨西哥 |
巴西 |
第十届 |
1974年 |
前西德 |
西德 |
第十一届 |
1978年 |
阿根廷 |
阿根廷 |
第十二届 |
1982年 |
西班牙 |
意大利 |
第十三届 |
1986年 |
墨西哥 |
阿根廷 |
第十四届 |
1990年 |
意大利 |
西德 |
第十五届 |
1994年 |
美国 |
巴西 |
第十六届 |
1998年 |
法国 |
法国 |
第十七届 |
2002年 |
韩日 |
巴西 |
第十八届 |
2006年 |
德国 |
意大利 |
第十九届 |
2010年 |
南非 |
西班牙 |
第二十届 |
2014年 |
巴西 |
德国 |
(Map)在原有世界杯Map 的基础上,增加如下功能: 读入一支球队的名字,输出该球队夺冠的年份列表。 例如,读入“巴西”,应当输出 1958 1962 1970 1994 2002 读入“荷兰”,应当输出 没有获得过世界杯
package com.jihelianxi; import java.util.HashMap; import java.util.Map; import java.util.Scanner; public class TestSjb { public static void main(String[] args) { Map<String,String> ma=new HashMap<>(); ma.put("1930","乌拉圭" ); ma.put("1934","意大利" ); ma.put("1938","意大利" ); ma.put("1950","乌拉圭" ); ma.put("1954","西德" ); ma.put("1958","巴西" ); ma.put("1962","巴西" ); ma.put("1966","英格兰" ); ma.put("1970","巴西" ); ma.put("1934","西德" ); Scanner sc=new Scanner(System.in); System.out.println("输入年份:"); String st=sc.nextLine(); if(ma.containsKey(st)==true) { System.out.println(st+"得冠国家是:"+ma.get(st)); } else { System.out.println(st+"没举办世界杯"); } Scanner sc1 = new Scanner(System.in); System.out.println("请输入夺冠球队"); String str1 = sc1.nextLine(); if(ma.containsValue(str1)==false) { System.out.println(str1+"队没有获得过冠军"); } else { System.out.println(str1+"队的夺冠年份是:"); for(String str :ma.keySet()) { if(ma.get(str).equals(str1)) { System.out.print(str+" "); } } } //遍历keySet集合 获取value // for(String st:ma.keySet()) // { // String b=ma.get(st); // } // // System.out.println("输入国家名字:"); // String str=sc.nextLine(); // for(int i=0;i<ma.size();i++) // { // if(b.equals(str)) // { // System.out.println(st); // } // else // { // System.out.println("没有获得过世界杯"); // } // } } }