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

注意事项:我在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分

0 人评分

C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:

一点编程也不会写的:零基础C语言学练课程

解决困扰你多年的C语言疑难杂症特性的C语言进阶课程

从零到写出一个爬虫的Python编程课程

只会语法写不出代码?手把手带你写100个编程真题的编程百练课程

信息学奥赛或C++选手的 必学C++课程

蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程

手把手讲解近五年真题的蓝桥杯辅导课程

评论列表 共有 0 条评论

暂无评论