7-4 jmu-Java-02基本语法-03-身份证排序 (10分) JAVA

输入n,然后连续输入n个身份证号。
然后根据输入的是sort1还是sort2,执行不同的功能。输入的不是sort1或sort2,则输出exit并退出。
输入sort1,将每个身份证的年月日抽取出来,按年-月-日格式组装,然后对组装后的年-月-日升序输出。
输入sort2,将所有身份证按照里面的年月日升序输出。
注意:处理输入的时候,全部使用Scanner的nextLine()方法,以免出错。

输入样例:

6
410425198309308225
320203197206115011
431227196108033146
330226196605054190
34080019810819327X
320111197112301539
sort1
sort2
e

输出样例:

1961-08-03
1966-05-05
1971-12-30
1972-06-11
1981-08-19
1983-09-30
431227196108033146
330226196605054190
320111197112301539
320203197206115011
34080019810819327X
410425198309308225
exit

代码实现:


import java.util.*;

public class Main {
    public static void main(String[] args) {
        Scanner scan = new Scanner(System.in);
        //输入
        int n = Integer.valueOf(scan.nextLine());
        String[] array = new String[n];//id组
        for (int i=0;i<n;i++){
            array[i] = scan.nextLine();
        }
        while (n>0){
            String a =scan.nextLine();
           switch (a){
               case "sort1":
                   String[] newArray = new String[n];
                   for (int i=0;i<n;i++){
                       newArray[i] =  (((array[i].substring(6,10).concat("-")).concat(array[i].substring(10,12))).concat("-")).concat(array[i].substring(12,14));
                   }
                   Arrays.sort(newArray, new Comparator<String>() {
                       public int compare(String o1, String o2) {
                           return o1.compareTo(o2);
                       }
                   });
                   for (String v:newArray){
                       System.out.println(v);
                   }
                   break;
               case "sort2":
                   String[] date = new String[n];
                   int[] indx = new int[n];
                   List<String> st = new ArrayList<>();
                   List<String> list = new ArrayList<>();
                   for (int i=0;i<n;i++){
                       date[i] =array[i].substring(6,14);
                       st.add(array[i]);//包装数组
                       list.add(date[i]);//包装年月日
                   }
//                   Collections.sort(list);
                   for (int i=0;i<n;i++){
                       indx[i] = Integer.valueOf(list.get(i));
                   }
                   Arrays.sort(indx);

                   for (int i=0;i<n;i++){
                       System.out.println(st.get(list.indexOf(Integer.toString(indx[i]))));
                   }

                   break;
               default:
                   System.out.println("exit");


           }
           
        }
    }
}

7-3 jmu-Java-02基本语法-02-StringBuilder (10分)

输入3个整数n、begin、end。 首先,使用如下代码:

for(int i=0;i<n;i++)
将从0到n-1的数字拼接为字符串str。如,n=12,则拼接出来的字符串为01234567891011

最后截取字符串str从begin到end(包括begin,但不包括end)之间的字符串,并输出。

输入样例:

10
5
8
1000
800
900

输出样例:

567
0330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533

代码实现:

import java.util.Scanner;

public class Main {
    public static void main(String[] args) {
        Scanner scan = new Scanner(System.in);
        while(true){
              int n = scan.nextInt();
        int begin = scan.nextInt();
        int end = scan.nextInt();
        StringBuilder s = new StringBuilder();
        for(int i=0;i<n;i++){
            s.append(i);
        }
        System.out.println( s.substring(begin,end));                   
        } 
    }
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值