编写Java程序,输入N个用户的姓名和电话号码,按照用户姓名的词典顺序排列输出用户的姓名和电话号码
【输入形式】用户首先在第一行输入一个正整数,该正整数表示待排序的用户数目,然后在下面多行输入多个用户的信息,每行的输入格式为:姓名电话。以回车结束每个用户的输入。【输出形...
【输入形式】用户首先在第一行输入一个正整数,该正整数表示待排序的用户数目,然后在下面多行输入多个用户的信息,每行的输入格式为:姓名 电话。以回车结束每个用户的输入。
【输出形式】程序输出排序后的结果。每行的输出结果格式也是: 姓名 电话。姓名和电话字段中间没有空格,要求用户姓名不能超过10个字符,超出10个字符时候只取前10个字符作为姓名。电话号码不能超过10位,超过10位时只按10位处理。输出姓名、电话字段各占12个字符宽,输出格式采用默认对齐方式。另外,用户的数量要求不超过50个。
【样例输入】
3
amethystic 1234567
amethyst 654321
wangwei 7645434
【样例输出】
####amethyst######654321
##amethystic#####1234567
#####wangwei#####7645434
【样例说明】程序根据用户姓名的词典顺序排序,最后按照姓名#电话的格式输出。另外,由于规定姓名和电话之间用空格分割,所以输入姓名时请将姓和名一起输入,中间不要有空格。另外输出时候程序将自动补齐12字符宽。程序输出结尾有个回车符。 展开
【输出形式】程序输出排序后的结果。每行的输出结果格式也是: 姓名 电话。姓名和电话字段中间没有空格,要求用户姓名不能超过10个字符,超出10个字符时候只取前10个字符作为姓名。电话号码不能超过10位,超过10位时只按10位处理。输出姓名、电话字段各占12个字符宽,输出格式采用默认对齐方式。另外,用户的数量要求不超过50个。
【样例输入】
3
amethystic 1234567
amethyst 654321
wangwei 7645434
【样例输出】
####amethyst######654321
##amethystic#####1234567
#####wangwei#####7645434
【样例说明】程序根据用户姓名的词典顺序排序,最后按照姓名#电话的格式输出。另外,由于规定姓名和电话之间用空格分割,所以输入姓名时请将姓和名一起输入,中间不要有空格。另外输出时候程序将自动补齐12字符宽。程序输出结尾有个回车符。 展开
展开全部
如下:看看满不满足要求,不对追问。
import java.util.ArrayList;
import java.util.Collections;
import java.util.Comparator;
import java.util.HashMap;
import java.util.Scanner;
public class B {
public static void main(String[] args) {
Scanner in = new Scanner(System.in);
int n = in.nextInt();
if(n > 50) {
System.out.print("No more than 50 contacts");
in.close();
return ;
}
ArrayList<HashMap.Entry<String, String>> list;
HashMap<String, String> map = new HashMap<>();
//String [][]contact = new String [n][2];
for(int i = 0; i < n; i ++) {
String [] temp = new String [2];
temp[0] = in.next();
if(temp[0].length() > 10) {
temp[0] = temp[0].substring(0, 10);
}
temp[1] = in.next();
if(temp[1].length() > 10) {
temp[1] = temp[1].substring(0, 10);
}
map.put(temp[0], temp[1]);
}
in.close();
list = new ArrayList<>(map.entrySet());
Collections.sort(list, new Compare());
for(int i = 0; i < n; i ++) {
System.out.println(format(list.get(i).getKey()) + format(list.get(i).getValue()));
}
}
static String format(String s) {
char [] c = new char[12 - s.length()];
for(int i = 0; i < c.length; i ++) {
c[i] = '#';
}
return String.valueOf(c) + s;
}
static class Compare implements Comparator<HashMap.Entry<String, String>> {
@Override
public int compare(HashMap.Entry<String, String> o1, HashMap.Entry<String, String> o2) {
int temp = o1.getKey().compareTo(o2.getKey());
if (temp > 0) {
return 1;
} else if (temp == 0) {
return 0;
} else {
return -1;
}
}
}
}
结果:
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询