java 并交集运算】的更多相关文章

在面试的过程中,忘记了List中还可以进行交并集运算,这也是常见的数据问题啊,这也是常见的数据结构问题---集合,面试的过程中一直没有想到这种数据结构 java中API中已经集成了并交集的运算. 代码:(from http://pengyan5945.iteye.com/blog/1311597) 交集的API:使用retainAll即可 并集的API:先removeAll 再addAll import java.util.ArrayList; import java.util.HashSet;…
位运算:二进制运算 Java的异或运算^ 真^假=真 假^真=真 假^假=假 真^真= 假,这四个是在网上copy的例子,真是1,假是0 但它却是说明了Java异或运算的基本法则,那就是:只要两个条件同时为真或假,其结果都为假(这里要注意区别 Java的与运算---其为真真为真,假假为假): 但仅当两条件中一个为真,另一个为假时,结果为真(感觉有点叛逆哦?不合常理,不走寻常路). 但 Java的异或运算还有一个前提那就是它都是以二进制数据为基础进行的运算. 也就是说当我们在使用代码中使用到异或运…
java 取模运算%  实则取余 简述 例子 应用在数据库分库分表 取模运算 求模运算与求余运算不同.“模”是“Mod”的音译,模运算多应用于程序编写中. Mod的含义为求余.模运算在数论和程序设计中都有着广泛的应用,从奇偶数的判别到素数的判别,从模幂运算到最大公约数的求法,从孙子问题到凯撒密码问题,无不充斥着模运算的身影.虽然很多数论教材上对模运算都有一定的介绍,但多数都是以纯理论为主,对于模运算在程序设计中的应用涉及不多. 取余运算区别 对于整型数a,b来说,取模运算或者求余运算的方法都是:…
Java的整数运算遵循四则运算规则,可以使用任意嵌套的小括号.四则运算规则和初等数学一致.例如: public class Main { public static void main(String[] args) { int i=(100+200)*(99-88);//3300 int n=7*(5+(i-9));//23072 System.out.println(i); System.out.println(n); } } 输出 3300 23072 整数运算的数值不但是精确的,而且整数运…
在初中代数中,我们经常会求两个集合的并集.交集.差集等,在Java中也存在着此 类运算,那如何实现呢? 一提到此类集合操作,大部分的实现者都会说:对两个集合进行遍历,即可求出结果.是的,遍历可以实现并集.交集.差集等运算,但这不是最优雅的处理方式.下面来看看如何进行更优雅.快速.方便的集合操作. (1) 并集,(2)交集,(3)差集(补集),(4)无重复并集. 也叫做合集,把两个集合加起来即可,这非常简单,代码如下: import java.util.ArrayList; import java…
list集合运算 import java.io.ByteArrayInputStream; import java.io.ByteArrayOutputStream; import java.io.IOException; import java.io.ObjectInputStream; import java.io.ObjectOutputStream; import java.util.ArrayList; import java.util.List; public class ListD…
package com; import java.util.ArrayList;import java.util.Iterator;import java.util.List; public class Test { public static void main(String[] args) {  List list1 =new ArrayList();  list1.add("1111");  list1.add("2222");  list1.add(&quo…
INTERSECT交集是由既属于集合A,又属于集合B的所有元素组成的集合,如示意图1.…
<1>.在了解位移之前,先了解一下正数和负数的二进制表示形式以及关系:举例15和-15:15 的原码: 00000000 00000000 00000000 00001111     补码: 11111111 11111111 11111111 11110000                 +1 = -15的原码:11111111 11111111 11111111 11110001负数的原码即为:正数的原码取反,再加1.<2>位移操作:(只针对 int类型的数据有效,java…
多线程有两种实现方式: 一种是实现Runnable接口,另一种是继承Thread类,这两种方式都有缺点,run方法没有返回值,不能抛出异常(这两个缺点归根到底是Runable接口的缺陷,Thread也是实现了Runnable接口),如果需要知道一个线程的运行结果就需要用户自行设计,线程类自身也不能提供返回值和异常. 但是从JDK1.5之后引入了一个新的接口Callable,它类似于Runnable接口,实现它就可以实现多线程任务,Callable接口的定义如下: public interface…
今天看到一位大神的博客,深受感触.决定也发一篇博客,证明一下我还活着. 于是我翻看以前学习时做的一些笔记,整理了一下,得到了一个关于异或运算交换变量变量值的笔记. 首先来看下面三组表达式,看起来他们都能实现交换两个变量的值. a = a ^ b; b = a ^ b; a = a ^ b; a = a ^ (b = b ^ (a = a ^ b)); a ^= b ^= a ^= b; 可实际的情况是,前面2组表达式,在C.C++.Java中都能顺利完成变量值的交换.而第3组表达式,却只在C.C…
(一),Java基本类型及运算 注释:可以用于生成API: 命令如:javadoc -d apidoc windowtitle hhh -doctitle aaa  -header bbbb -version -author *HelloWorld.java 注意点: 1,标识符只能是字母,数字,下划线和$,其中数字不能作为开头 2,基本类型:1个字节对应于计算机的8位二进制,计算机以补码的形式存取整数,即正数的补码为其本身,而负数的补码为其反码(处最高位,其余位取反)然后加一 3,类型装换:小…
/** * Created by yuhui on 2017/7/11 0011. */ import java.util.HashSet; import java.util.Set; public class TestSet { public static void main(String[] args) { Set<String> result = new HashSet<String>(); Set<String> set1 = new HashSet<St…
1byte(字节)=8bit(比特) 1 0 0 0 0 0 0 0 1   2进制的1的原码 反码 补码 0 0 0 0 0 0 0 0   2进制的0的原码 反码 补码 -1 1 0 0 0 0 0 0 1 计算机中真正参与运算的是  补码! 在java中所有的数字都是有符号的!  符号就是  正 0   负 1 最高位(最左边的)的 0和1 就是 符号位 什么是最高位? 就是最左边的数字! java中最小的单位是 byte(字节) 生活中我们买了一个50G的内存条! 插入到我们的电脑中 有…
java运算符 与(&).非(~).或(|).异或(^)   最近看HashMap源码,遇到了这样一段代码: 1 static final int hash(Object key) { 2 int h; 3 return (key == null) ? 0 : (h = key.hashCode()) ^ (h >>> 16); 4 } 于是我整理学习了以下知识:1.十进制转二进制 原理:给定的数循环除以2,直到商为0或者1为止.将每一步除的结果的余数记录下来,然后反过来就得到相…
变量 1.变量名可以使用 数字.字母.下划线.$符号.数字包括 '0'~'9' 和某种语言中表示数字的任何 Unicode 字符.字母包括 'A'~'Z'.'a'~'z' 和某种语言中表示字母的任何 Unicode 字符. 2.变量名里尽量不要出现 $ 字符,它只用在Java编译器或其他工具生成的名字中.不要使用Java保留字作为变量名. 3.可以在一行中声明多个变量,不提倡使用,使用逐一声明每个变量可以提高程序的可读性. 4.声明一个变量后,必须用赋值语句对变量进行显式初始化.可以将变量的声明…
package cn.sasa.demo5; import java.math.BigDecimal; import java.math.BigInteger; public class BigDataDemo { public static void main(String[] args) { //BigInteger //数字太大,超过了long的范围 //long num1 = 9999999999999999999999999999999999999999999999L; BigInte…
除法运算的函数定义如下 BigDecimal.divide(BigDecimal divisor, int scale, RoundingMode roundingMode) ; scale为小数位数: Java中BigDecimal取整方法,scale为0 BigDecimal bd = new BigDecimal("12.1"); long l = bd.setScale( 0, BigDecimal.ROUND_UP ).longValue(); // 向上取整 long l…
        文章部分代码图片和总结来自参考资料 哈希和常用的方法 散列,从中文字面意思就很好理解了,分散排列,我们知道数组地址空间连续,查找快,增删慢,而链表,查找慢,增删快,两者结合起来形成散列表.如下图. 常见的hash 散列方法有 : 直接定址法:直接以关键字k或者k加上某个常数(k+c)作为哈希地址. 数字分析法:提取关键字中取值比较均匀的数字作为哈希地址.(ThreadLocalMap中取的斐波那契数列数 0x61c88647 ) 除留余数法:用关键字k除以某个不大于哈希表长度m的…
在学习某个加密算法的时候留意到模运算,仔细查了资料后才注意到Java中的 % 其实是取余而不是取模,但是百度的时候找到的很多文章都把Java的 % 直接当成取模来用了,为了少踩坑所以自己整理了一下写了点笔记.顺便一提垃圾百度的坑太多了,错的东西都能推一大堆到第一页,英语过关而且能FQ的还是翻出去找资源吧. 链接地址: https://shimo.im/docs/OFgGmnPHayU3Y08L/ 这是我的第一条博客,有误的话请大佬们多多包涵,轻喷…
1.运算符 (1)算术运算符 A:+,-,*,/,%,++,-- B:+的用法 [a.加法] [b.正号] [c.字符串连接付] C:/和%的区别 [数据做除法的时候,/取的是商,%取的是余数] D:++和--的用法 [a.单独使用时:放在 操作数据的前面和后面效果是一样的,a++或者++a效果是一样的] [b.参与操作运算时-放在操作数的前面:先自增或者自减,再参与操作] [c.参与操作运算时-放在操作数的后面:先参与操作,再自增或者自减] [例子解析] (2)赋值运算符 A:=,+=,*=,…
java中运算都是操作符号,那么整形默认为int,双精度默认为都double 整数 看案例: 无法编译通过:操作默认为int,接受结果为int,所以这个地方编译无法通过,所以需要强制类型转换 再看案例: 再看双精度: 这种是可以的,再看 这也是可以的,看结果: 精度损失.再看 结果: 再看多种案例: 看结果: 再看案例 : 看结果 那么会什么会出现这么多问题呢,原因 在数据结果,转为二进制的时候,比如0.3  转换为二进制如这么转换的 0.3*2->0.6->0.6*2>1.2   二进…
浮点数运算和整数运算相比,只能进行加减乘除这些数值运算,不能做位运算和移位运算. 在计算机中,浮点数虽然表示的范围很大,但是浮点数有个非常重要的特点,就是浮点数常常无法精确表示 举例 浮点数0.1在计算机中就无法精确表示,因为十进制的0.1换算成二进制是一个无限循环小数,很显然,无论使用float还是double,都只能存储一个0.1的近似值.但是,0.5这个浮点数又可以精确地表示.因为浮点数常常无法精确表示,因此,浮点数运算会产生误差: public class Main { public s…
//java实现求交集,并集,包括元素为对象和基本类型,主要是利用hashMap,set不允许元素重复等特性来进行实现去重,利用反射机制来灵活配置以对象某个属性来进行去重./** * Gaoxl * 求并集去重 * 基本类型和对象 * @param list1 * @param list2 * @param fieldName(用于去重的对象属性名) * @return */ public static <T> List<T> getUnion(List<T> list…
1 问题描述 编程实现两个复数的运算.设有两个复数 和 ,则他们的运算公式为: 要求:(1)定义一个结构体类型来描述复数. (2)复数之间的加法.减法.乘法和除法分别用不用的函数来实现. (3)必须使用结构体指针的方法把函数的计算结果返回. 说明:用户输入:运算符号(+,-,*,/) a b c d. 输出:a+bi,输出时不管a,b是小于0或等于0都按该格式输出,输出时a,b都保留两位. 输入: - 2.5 3.6 1.5 4.9 输出: 1.00±1.30i 2 解决方案 package c…
/* 目的:测试变量的运算方式 结果:byte a, b, c; a = b+c; 或者 a = b+10 形如这种形式的算式, 等式的右边的运算结果默认的都是int型的!因为等式右边有变量, 编译器无法确定变量的内容 ,因为它是变量!所以相加之后得到的int再默认强制转换成byte可能会损失精度. 而形如 a=4+5:这种常量的赋值,虽然 4 和 5 都默认的是int, 但都是常量,它们的值是确定的!所以如果 4+5的值超过了 byte的最大值的范围, 那就会编译出错!(也就是等式右边都是常量…
import com.sun.media.sound.SoftSynthesizer; import java.util.*;   public class a123 { public static void main(String args[]) { int m, n; Scanner in = new Scanner(System.in); while ((m = in.nextInt()) != 0 | (n = in.nextInt()) != 0) { if (m <= 100 &…
首先定义两个list List list1 =new ArrayList(); list1.add("); list1.add("); list1.add("); List list2 =new ArrayList(); list2.add("); list2.add("); list2.add("); 运行: ; i < list1.size(); i++) { System.out.println(list1.get(i)); } 并集…
一.数据类型 1.基本数据类型: . 布尔类型:boolean(true,false) . 整型:byte(-128,127).short(-32768,32767).int(-2147483648,2147483647).long(-9223372036854775808,9223372036854775807).char(\u0000' ,'\uffff) . 浮点数:float(1.4E-45,3.4028235E38).double(4.9E-324,1.7976931348623157…
1.团队课程设计博客链接 洪亚文博客链接:http://www.cnblogs.com/201521123065hyw/ 郑晓丽博客链接:http://www.cnblogs.com/zxl3066/ 2.个人负责模块或任务说明 负责模块:整个表达式的计算流程 3.自己的代码提交记录截图 for (int i = 0; i < array.length; i++) { for(int k=i;array[k] >= '0' && array[k] <= '9';k++,i…