编写Java程序,输入N个用户的姓名和电话号码,按照用户姓名的词典顺序排列输出用户的姓名和电话号码

【输入形式】用户首先在第一行输入一个正整数,该正整数表示待排序的用户数目,然后在下面多行输入多个用户的信息,每行的输入格式为:姓名电话。以回车结束每个用户的输入。【输出形... 【输入形式】用户首先在第一行输入一个正整数,该正整数表示待排序的用户数目,然后在下面多行输入多个用户的信息,每行的输入格式为:姓名 电话。以回车结束每个用户的输入。
【输出形式】程序输出排序后的结果。每行的输出结果格式也是: 姓名 电话。姓名和电话字段中间没有空格,要求用户姓名不能超过10个字符,超出10个字符时候只取前10个字符作为姓名。电话号码不能超过10位,超过10位时只按10位处理。输出姓名、电话字段各占12个字符宽,输出格式采用默认对齐方式。另外,用户的数量要求不超过50个。
【样例输入】
3
amethystic 1234567
amethyst 654321
wangwei 7645434
【样例输出】
####amethyst######654321
##amethystic#####1234567
#####wangwei#####7645434
【样例说明】程序根据用户姓名的词典顺序排序,最后按照姓名#电话的格式输出。另外,由于规定姓名和电话之间用空格分割,所以输入姓名时请将姓和名一起输入,中间不要有空格。另外输出时候程序将自动补齐12字符宽。程序输出结尾有个回车符。
展开
 我来答
1259049661
2018-11-26 · TA获得超过1552个赞
知道小有建树答主
回答量:333
采纳率:88%
帮助的人:212万
展开全部

如下:看看满不满足要求,不对追问。

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;
}
}
}
}

结果:

推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式