1. package com.test;
  2. import java.util.ArrayList;
  3. import java.util.Arrays;
  4. import java.util.Collections;
  5. import java.util.List;
  6. /**
  7. *
  8. * 找出两个list中不同的元素
  9. * @author leiwei 2011-12-14
  10. *
  11. */
  12. public class NoEqualsElement {
  13. public static void main(String[] args) {
  14. List<String> list1 = new ArrayList<String>();
  15. List<String> list2 = new ArrayList<String>();
  16. list1.add("1");
  17. list1.add("3");
  18. list1.add("8");
  19. list1.add("9");
  20. list2.add("2");
  21. list2.add("3");
  22. list2.add("7");
  23. for(String s2:list1) {
  24. boolean flag = false;
  25. for(String s1:list2) {
  26. if(s2.equals(s1)) {
  27. flag = true;
  28. break;
  29. }
  30. }
  31. if(!flag){
  32. System.out.println(s2);
  33. }
  34. }
  35. }
  36. }
  1. package com.test;
  2. import java.util.ArrayList;
  3. import java.util.HashSet;
  4. import java.util.Iterator;
  5. import java.util.List;
  6. import java.util.Set;
  7. import com.model.Student;
  8. /**
  9. * 重写对象Student的equals方法
  10. * 只要age相等 对象就相等
  11. *
  12. * 删除两个集合中 相同的对象只保留一个
  13. * @author leiwei 2011-12-19
  14. *
  15. */
  16. public class ListOBJ {
  17. public static void main(String[] args) {
  18. Set<Student> setStudent = new HashSet<Student>();
  19. List<Student> list1 = new ArrayList<Student>();
  20. List<Student> list2 = new ArrayList<Student>();
  21. Student s1 = new Student();
  22. s1.setAge("10");
  23. list1.add(s1);
  24. Student s2 = new Student();
  25. s2.setAge("20");
  26. list1.add(s2);
  27. Student s3 = new Student();
  28. s3.setAge("20");
  29. list2.add(s3);
  30. Student s4 = new Student();
  31. s4.setAge("30");
  32. list2.add(s4);
  33. /**
  34. * 我们知道set集合,中的元素不会重复
  35. *
  36. * 将连个对象集合放进去,自然就会排出重复的
  37. *
  38. * 对象(前提Student 对象重写了equals方法)
  39. */
  40. setStudent.addAll(list1);
  41. setStudent.addAll(list2);
  42. //输出 测试看是否 排出成功
  43. System.out.println(setStudent.size());
  44. Iterator<Student> iterator = setStudent.iterator();
  45. while (iterator.hasNext()) {
  46. Student s = iterator.next();
  47. System.out.println(s.getAge());
  48. }
  49. }
  50. }
  1. package com.model;
  2. public class Student {
  3. private String age;
  4. public String getAge() {
  5. return age;
  6. }
  7. public void setAge(String age) {
  8. this.age = age;
  9. }
  10. //重写equals方法只要age相等,我们就认为对象两个相等
  11. @Override
  12. public boolean equals(Object obj) {
  13. if(obj instanceof Student){
  14. Student st=(Student) obj;
  15. return (age.equals(st.age));
  16. }else{
  17. return super.equals(obj);
  18. }
  19. }
  20. @Override
  21. public int hashCode() {
  22. return age.hashCode();
  23. }
  24. }

转自:http://blog.csdn.net/goodleiwei/article/details/7083199

找出list中的不同元素、删除两个list中相同的对象的更多相关文章

  1. c#封装DBHelper类 c# 图片加水印 (摘)C#生成随机数的三种方法 使用LINQ、Lambda 表达式 、委托快速比较两个集合,找出需要新增、修改、删除的对象 c# 制作正方形图片 JavaScript 事件循环及异步原理(完全指北)

    c#封装DBHelper类   public enum EffentNextType { /// <summary> /// 对其他语句无任何影响 /// </summary> ...

  2. java:在Conllection接口中实际上也规定了两个可以将集合变成对象数组的操作

    在Conllection接口中实际上也规定了两个可以将集合变成对象数组的操作 //在Conllection接口中实际上也规定了两个可以将集合变成对象数组的操作 List<String> a ...

  3. majority element(数组中找出出现次数最多的元素)

    Given an array of size n, find the majority element. The majority element is the element that appear ...

  4. 笔试算法题(24):找出出现次数超过一半的元素 & 二叉树最近公共父节点

    出题:数组中有一个数字出现的次数超过了数组长度的一半,请找出这个数字: 分析: 解法1:首先对数组进行排序,时间复杂度为O(NlogN),由于有一个数字出现次数超过了数组的一半,所以如果二分数组的话, ...

  5. 算法练习之x的平方根,爬楼梯,删除排序链表中的重复元素, 合并两个有序数组

    1.x的平方根 java (1)直接使用函数 class Solution { public int mySqrt(int x) { int rs = 0; rs = (int)Math.sqrt(x ...

  6. 使用LINQ、Lambda 表达式 、委托快速比较两个集合,找出需要新增、修改、删除的对象

    本文需要对C#里的LINQ.Lambda 表达式 .委托有一定了解. 在工作中,经常遇到需要对比两个集合的场景,如: 页面集合数据修改,需要保存到数据库 全量同步上游数据到本系统数据库 在这些场景中, ...

  7. 算法-找出与目标数字相同的digit组成的整数中比该数字大的数集中的最小数字

    题目: 给出1个正整数,找到用与这个数字相同的digit组成的整数中比这个数字大的数集中的最小数字.比如:12352874 的结果是 12354278 分析: 这道题目的考虑目标是数组的查找与排序. ...

  8. day6、Linux下如何找出7天以前的文件删除

    有些时候,由于系统产生的日志文件,使服务器的磁盘空间紧张,所以怎么删除7天以前的日志文件及让系统只保留7天以内的日志文件 方法一 使用命令:find + |xargs + ls 命令方法:find / ...

  9. EF Core中Fluent Api如何删除指定数据表中的行

    这两天一直在研究在code first下如何删除数据表中的指定行,于是开始搜狗,后来百度,压根就找不到资料,后来一想可能我的搜索关键字有问题,而且ef core命令与ef的命令差不多,于是从这两个方面 ...

随机推荐

  1. noip模拟赛 #3

    T1 给一个环,每个点有一个权值,把环分成三段,求最小的那段的最大值 sol:暴力 二分答案,chk就是把环搞成三倍链,每次枚举起点,后面三个切割点都可以二分找 然后就Rua过去了 //yyc wen ...

  2. 系列文章--8天学通MongoDB

    随笔分类 - MongoDB 8天学通MongoDB——第八天 驱动实践 摘要: 作为系列的最后一篇,得要说说C#驱动对mongodb的操作,目前驱动有两种:官方驱动和samus驱动,不过我个人还是喜 ...

  3. 一个内存增长问题的分析和处理(二)——valgrind工具的用法

    valgrind是linux下对C++和C程序进行内存泄露检测的工具,除了内存检测,valgrind还提供了很多其他的功能,这里主要介绍下valgrind的内存检测的功能. 首先是文件的下载,valg ...

  4. BZOJ2428:[HAOI2006]均分数据

    我对模拟退火的理解:https://www.cnblogs.com/AKMer/p/9580982.html 题目传送门:https://www.lydsy.com/JudgeOnline/probl ...

  5. mysql du-master配置

    db-server1 my.cnf log_bin = mysql-binbinlog_format = mixedserver_id = 1 read-only = 0#binlog-do-db = ...

  6. CCS V5 使用教程三:程序调试

    官网教程 新建调试工程 输入以下源码: #include <stdio.h> #include <c6x.h> ]; void main(void) { unsigned ; ...

  7. HDOJ2553(2N皇后问题)

    N皇后问题 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Submi ...

  8. Excel特殊格式的列

    1.根据前两列显示天时分格式,算出所需时间列的内容=DAY(O2-N2)&"天"&HOUR(O2-N2)&"小时"&MINUTE ...

  9. 《Kubernetes权威指南第2版》学习(四)kubernetes基本概念和术语

    1: etcd是干什么的: 键-值存储仓库,用来配置共享和服务发现. k8s把Node, pod,replication controller, Services看做是资源对象,这些资源对象可以通过K ...

  10. oracle--视图(2)---

    Oracle---视图 视图是基于一个表或多个表或视图的逻辑表,本身不包含数据,通过它可以对表里面的数据进行查询和修改.视图基于的表称为基表,Oracle的数据库对象分为五种:表,视图,序列,索引和同 ...