七月


私信TA

用户名:yuzefeng

访问量:4655

签 名:

等  级
排  名 1734
经  验 2678
参赛次数 0
文章发表 38
年  龄 0
在职情况 学生
学  校 成都理工大学
专  业

  自我简介:

解题思路:利用两个列表去操作,按顺序输入,只要比较固定的位置,删除元素即可。思路很简单,代码有些复杂

注意事项:我在alist列表给了类型,不然的话,在最后面输出时。i的类型要变成object

参考代码:


import java.util.*;

public class Main {
   public static void main(String[] args) {
         Scanner scanner = new Scanner(System.in);
         int m = scanner.nextInt();
         int n = scanner.nextInt();
         ArrayList <Integer> alist = new ArrayList(2*m);    //链表a
         ArrayList blist = new ArrayList(2*n);    //链表b
         for(int i = 0;i < m;i++){
             alist.add(scanner.nextInt());
             alist.add(scanner.nextInt());   //按顺序输入学号和成绩
         }
         for(int i = 0;i < n;i++){
             blist.add(scanner.nextInt());
             blist.add(scanner.nextInt());
         }
         for(int j = 0;j< blist.size();j += 2){
             for(int i = 0;i<alist.size();i += 2){
                 if(blist.get(j) == alist.get(i)){
                     alist.remove(i+1);
                     alist.remove(i);    //学号位置比较,相同就从a列表删除,记得先删成绩,不然位置会错乱

                 }

             }
         }
         System.out.println(alist.size()/2);
         for(int i:alist)
             System.out.print(i+" ");







   }
}


//        =============Dragon be here!==========/
//            ┏┓   ┏┓
//           ┏┛┻━━━┛┻┓
//           ┃       ┃
//           ┃   ━   ┃
//           ┃ ┳┛ ┗┳ ┃
//           ┃       ┃
//           ┃   ┻   ┃
//           ┃       ┃
//           ┗━┓   ┏━┛
//             ┃   ┃神兽保佑
//             ┃   ┃代码无BUG!
//             ┃   ┗━━━┓
//             ┃       ┣┓
//             ┃       ┏┛
//             ┗┓┓┏━┳┓┏┛
//              ┃┫┫ ┃┫┫
//              ┗┻┛ ┗┻┛
//         ━━━━━━神兽出没━━━━━━

 

0.0分

0 人评分

  评论区

  • «
  • »