编程题:sdut-String+array(LinkedHashMap) 读中国载人航天史,汇航天员数量,向航天员致敬(1)
1986年,中国实施“863”计划,航天技术列入其中。以载人飞船开始起步,最终建成我国的空间站。
1992年9月21日,中国实施载人航天工程,并确定了三步走的发展战略:第一步,发射载人飞船,建成初步配套的试验性载人飞船工程。第二步,突破载人飞船和空间飞行器的交会对接技术,利用载人飞船技术改装、发射一个空间实验室。第三步,建造载人空间站。
在长期的奋斗中,我国航天工作者不仅创造了非凡的业绩,而且铸就了特别能吃苦、特别能战斗、特别能攻关、特别能奉献的载人航天精神。载人航天精神,是“两弹一星”精神在新时期的发扬光大,是我们伟大民族精神的生动体现,永远值得全党、全军和全国人民学习。
截至2021年4月,历任航天英雄名字如下:
杨利伟(神舟五号)
费俊龙、聂海胜(神舟六号)
翟志刚、景海鹏、刘伯明(神舟七号)
景海鹏、刘旺、刘洋(神舟九号)
聂海胜、张晓光、王亚平(神舟十号)
景海鹏、陈东(神舟十一号)
会编程的小伙伴们,请以他们出征太空的先后顺序,统计一下航天英雄们出征太空的次数,以实际行动向航天员们致敬!
### 输入格式:
每次航天飞船的编号为一行读入数据,分别读入每次飞上太空的航天英雄的姓名,名字中间有一个空格分隔。
最后一行为“end“,表示输入结束。
提示:目前,中国航天员的数量小于20。
### 输出格式:
以出征太空的先后顺序,统计航天英雄们出征太空的次数。
每位航天员占一行,航天员姓名与出征次数中间有一个空格。
### 输入样例:
in
杨利伟
费俊龙 聂海胜
翟志刚 景海鹏 刘伯明
景海鹏 刘旺 刘洋
聂海胜 张晓光 王亚平
景海鹏 陈东
end
### 输出样例:
out
杨利伟 1
费俊龙 1
聂海胜 2
翟志刚 1
景海鹏 3
刘伯明 1
刘旺 1
刘洋 1
张晓光 1
王亚平 1
陈东 1
提示:
* 对于Java语言,此题有两种解决方案:
* (1)使用数组来解决;
* (2)使用java.util.Map接口的实现类LinkedMap来解决。
* LinkedHashMap是HashMap的子类,保证在遍历map元素时,可以按照添加的顺序实现遍历,对于频繁的遍历操作,它的执 行效率高于HashMap.
* 对于Python语言,。。。。
* 对于C语言,。。。。。。。
答案:若无答案欢迎评论
//方案一、利用数组解决 分别设计航天员姓名数组和对应的出征次数数组
import java.util.Arrays;
import java.util.Scanner;
public class Main {
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
String name=null;
String[] names=new String[20]; //航天员姓名数组
int[] count=new int[20]; //出征次数数组
int i=0;
int flag=0; //航天员是否已加入数组中
while(true)
{
flag=0;
name=sc.next(); //读一个姓名
if(name.equals("end"))
break;
//首先检查一下姓名是否在names[0]——names[i-1]中出现过
for(int j=0;j<i;j++)
{
if(name.equals(names[j])) //如果出现过
{
count[j]++; //则对应的统计次数加1
flag=1; //标志位设置为1,表示无须再新增姓名
}
}
if(flag==0) //如果姓名未曾在names数组中出现过
{
names[i]=name; //则增加新名字
count[i]++; //对应的出现次数增加1
i++; //数组下标右移1个,便于存放新航天员姓名
}
//System.out.println(Arrays.toString(names));
//System.out.println(Arrays.toString(count));
}
i=0;
while(count[i]>0) //数组容量大,前面的数据非0,后面的为0,等于0的数据不输出
{
System.out.println(names[i]+" "+count[i]);
i++;
}
}
}
//方案二、利用LinkedHashMap来解决
/*
import java.util.LinkedHashMap;
import java.util.Map;
import java.util.Scanner;
public class Main {
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
String name=null;
Map<String,Integer> map=new LinkedHashMap<String,Integer>();
while(true)
{
name=sc.next();
if(name.equals("end"))
break;
map.put(name, map.getOrDefault(name, 0)+1);
}
for(String name1:map.keySet())
{
System.out.println(name1+" "+map.get(name1));
}
}
}
*/
1992年9月21日,中国实施载人航天工程,并确定了三步走的发展战略:第一步,发射载人飞船,建成初步配套的试验性载人飞船工程。第二步,突破载人飞船和空间飞行器的交会对接技术,利用载人飞船技术改装、发射一个空间实验室。第三步,建造载人空间站。
在长期的奋斗中,我国航天工作者不仅创造了非凡的业绩,而且铸就了特别能吃苦、特别能战斗、特别能攻关、特别能奉献的载人航天精神。载人航天精神,是“两弹一星”精神在新时期的发扬光大,是我们伟大民族精神的生动体现,永远值得全党、全军和全国人民学习。
截至2021年4月,历任航天英雄名字如下:
杨利伟(神舟五号)
费俊龙、聂海胜(神舟六号)
翟志刚、景海鹏、刘伯明(神舟七号)
景海鹏、刘旺、刘洋(神舟九号)
聂海胜、张晓光、王亚平(神舟十号)
景海鹏、陈东(神舟十一号)
会编程的小伙伴们,请以他们出征太空的先后顺序,统计一下航天英雄们出征太空的次数,以实际行动向航天员们致敬!
### 输入格式:
每次航天飞船的编号为一行读入数据,分别读入每次飞上太空的航天英雄的姓名,名字中间有一个空格分隔。
最后一行为“end“,表示输入结束。
提示:目前,中国航天员的数量小于20。
### 输出格式:
以出征太空的先后顺序,统计航天英雄们出征太空的次数。
每位航天员占一行,航天员姓名与出征次数中间有一个空格。
### 输入样例:
in
杨利伟
费俊龙 聂海胜
翟志刚 景海鹏 刘伯明
景海鹏 刘旺 刘洋
聂海胜 张晓光 王亚平
景海鹏 陈东
end
### 输出样例:
out
杨利伟 1
费俊龙 1
聂海胜 2
翟志刚 1
景海鹏 3
刘伯明 1
刘旺 1
刘洋 1
张晓光 1
王亚平 1
陈东 1
提示:
* 对于Java语言,此题有两种解决方案:
* (1)使用数组来解决;
* (2)使用java.util.Map接口的实现类LinkedMap来解决。
* LinkedHashMap是HashMap的子类,保证在遍历map元素时,可以按照添加的顺序实现遍历,对于频繁的遍历操作,它的执 行效率高于HashMap.
* 对于Python语言,。。。。
* 对于C语言,。。。。。。。
答案:若无答案欢迎评论
//方案一、利用数组解决 分别设计航天员姓名数组和对应的出征次数数组
import java.util.Arrays;
import java.util.Scanner;
public class Main {
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
String name=null;
String[] names=new String[20]; //航天员姓名数组
int[] count=new int[20]; //出征次数数组
int i=0;
int flag=0; //航天员是否已加入数组中
while(true)
{
flag=0;
name=sc.next(); //读一个姓名
if(name.equals("end"))
break;
//首先检查一下姓名是否在names[0]——names[i-1]中出现过
for(int j=0;j<i;j++)
{
if(name.equals(names[j])) //如果出现过
{
count[j]++; //则对应的统计次数加1
flag=1; //标志位设置为1,表示无须再新增姓名
}
}
if(flag==0) //如果姓名未曾在names数组中出现过
{
names[i]=name; //则增加新名字
count[i]++; //对应的出现次数增加1
i++; //数组下标右移1个,便于存放新航天员姓名
}
//System.out.println(Arrays.toString(names));
//System.out.println(Arrays.toString(count));
}
i=0;
while(count[i]>0) //数组容量大,前面的数据非0,后面的为0,等于0的数据不输出
{
System.out.println(names[i]+" "+count[i]);
i++;
}
}
}
//方案二、利用LinkedHashMap来解决
/*
import java.util.LinkedHashMap;
import java.util.Map;
import java.util.Scanner;
public class Main {
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
String name=null;
Map<String,Integer> map=new LinkedHashMap<String,Integer>();
while(true)
{
name=sc.next();
if(name.equals("end"))
break;
map.put(name, map.getOrDefault(name, 0)+1);
}
for(String name1:map.keySet())
{
System.out.println(name1+" "+map.get(name1));
}
}
}
*/