当前位置: 首页 > news >正文

成都网站制作公司dedecms百度app下载安装

成都网站制作公司dedecms,百度app下载安装,网站建设解决,求职网站怎么做位图 一个int类型32字节,可以表示0-31这32个数出没出现过,出现过1没出现0,再扩大一点搞个数组,就可以表示0-1023出没出现过,一个long类型可储存64位 如何把10位组成的数,第四位由1改成零 package class05…

位图

一个int类型32字节,可以表示0-31这32个数出没出现过,出现过1没出现0,再扩大一点搞个数组,就可以表示0-1023出没出现过,一个long类型可储存64位

如何把10位组成的数,第四位由1改成零

package class05;import java.util.HashSet;public class Code01_BitMap1 {public static class BitMap {private long[] bits;public BitMap(int max) {bits = new long[(max + 64) >> 6];//右移6位就是÷64的意思}	//要准备多少个long就是(max + 64) >> 6个public void add(int num) {//num÷64定位到是第几个整数,num%64定位到是第几个整数的第几位//而%64等价于&63(只保留n的后七位0-63,前面的&63后全为0)bits[num >> 6] |= (1L << (num & 63));//不能1左移32位,1默认是整形32位必须是1L}//删除public void delete(int num) {bits[num >> 6] &= ~(1L << (num & 63));//1左移这么些位然后取反,然后和n做与运算}//有没有某个数(这一位不是0就存在)public boolean contains(int num) {return (bits[num >> 6] & (1L << (num & 63))) != 0;}}//验证public static void main(String[] args) {System.out.println("测试开始!");int max = 10000;BitMap bitMap = new BitMap(max);//申请一个mapHashSet<Integer> set = new HashSet<>();//申请一个哈希set然后这俩作比较int testTime = 10000000;for (int i = 0; i < testTime; i++) {int num = (int) (Math.random() * (max + 1));double decide = Math.random();if (decide < 0.333) {bitMap.add(num);set.add(num);} else if (decide < 0.666) {bitMap.delete(num);set.remove(num);} else {if (bitMap.contains(num) != set.contains(num)) {System.out.println("Oops!");break;}}}for (int num = 0; num <= max; num++) {if (bitMap.contains(num) != set.contains(num)) {System.out.println("Oops!");}}System.out.println("测试结束!");}}

1.快速写出46的二进制形式46=32+14=32+8+4+2=101110

2,^异或运算等价于二进制无进位相加

3.a&b得到的结果<<1位得到进位信息

故a=46,b=20,c=两者无进位相加结果,d等于进位信息

c=0101110^0010100=0111010=58

d=a&b<<1=0000100<<1=0001000=8,c+d=66=a+b

但是违规了,本能用加号,所以要一直递归,直到进位信息为零

那a-b=add(a,add(~b+1)),a+(-b)

乘法

a*b,从右往左看b的二进制位,是1把a抄下来,是0不抄下来,a后面补一个零(左移1位),循环

除法

1.要用右移,左移会导致数据符号位改变

2.x右移i位,i=30.29...5,x<y说明第i位上要放0,x>>4,x>=y停,第四位 置1,然后当前的x-y即x-y<<4

3.如何回避掉系统最小值无法转成绝对值问题,举例假设系统最小值是-15我要计算-15/3

-15+1=-14,-14/3=-4,然后(-15)-(-4*3)计算差值得-3,然后-3/3得到-1把他和-4相加

a/b->        (a+1)/b=c  ->a-(b*c)=d  ->  d/b=e  ->c+e

 

package class05;// 测试链接:https://leetcode.com/problems/divide-two-integers
public class Code03_BitAddMinusMultiDiv {public static int add(int a, int b) {int sum = a;while (b != 0) {//无论如何不能用加号sum = a ^ b;//无进位相加信息b = (a & b) << 1;//进位信息b->b`a = sum;//a->a`,直到进位信息为零}return sum;}public static int negNum(int n) {return add(~n, 1);}public static int minus(int a, int b) {return add(a, negNum(b));}
//乘法public static int multi(int a, int b) {int res = 0;while (b != 0) {if ((b & 1) != 0) {//最末尾有1res = add(res, a);//接受此时的a}a <<= 1;//a后面补一个零b >>>= 1;//循环的步进条件}return res;}public static boolean isNeg(int n) {return n < 0;}public static int div(int a, int b) {int x = isNeg(a) ? negNum(a) : a;//先把ab设置成正数int y = isNeg(b) ? negNum(b) : b;//如果是负数转成绝对值,是正数就不变int res = 0;for (int i = 30; i >= 0; i = minus(i, 1)) {if ((x >> i) >= y) {res |= (1 << i);x = minus(x, y << i);}}//返回:如果ab符号不一样,加个负号再返回return isNeg(a) ^ isNeg(b) ? negNum(res) : res;}
//系统最小值无法转成绝对值(负数比正数多一个,比如最小是-10而最大是9),分类讨论public static int divide(int a, int b) {if (a == Integer.MIN_VALUE && b == Integer.MIN_VALUE) {return 1;} else if (b == Integer.MIN_VALUE) {return 0;} else if (a == Integer.MIN_VALUE) {if (b == negNum(1)) {//这个数不存在没有,约定俗成写最大值return Integer.MAX_VALUE;} else {int c = div(add(a, 1), b);return add(c, div(minus(a, multi(c, b)), b));}} else {return div(a, b);}}}

http://www.mmbaike.com/news/54863.html

相关文章:

  • 网站是否必须做认证网页设计模板免费网站
  • 欧卡乐网站建设seo推广培训资料
  • 帝国cms 调用网站名称成都十大营销策划公司
  • 做订阅号要建立网站吗北京疫情最新情况
  • 网页网站怎么做的吗工具大全
  • 公司网站域名cn和com视频广告接单平台
  • 华为官方商城网站建设方案广西seo快速排名
  • 企业网站开发知名品牌有哪些南京百度推广优化排名
  • 中国建设银行官网网站首页短视频seo推广
  • 杭州临平网站建设seo课程排行榜
  • 丹东市住房和城乡建设委员会网站百度贴吧官网首页
  • 黑河企业网站建设公司深圳全网信息流推广公司
  • 长沙专业网站建设运营佛山优化网站关键词
  • 留住用户网站短视频推广app
  • 海口个人建站模板北京网站建设公司哪家好
  • wordpress私有网盘站长工具seo综合查询源码
  • 关于网站建设维护的创业计划书要怎么网络做推广
  • 苏州专业高端网站建设天津百度
  • 个人网站备案建设方案书优化系统
  • 最好永久免费素材网廊坊网站排名优化公司哪家好
  • 南京自助网站建设口碑营销的形式
  • 山西大同专业网站建设制作价格南京seo外包
  • 企业营销网站建设公司哪家好什么是搜索引擎销售
  • 宝塔搭建完wordpressseo内链优化
  • php动态网站开发是干嘛的快速整站排名seo教程
  • 你有网站 我做房东 只收佣金的网上海百度搜索优化
  • 广元网站建设价格网红推广团队去哪里找
  • 长春网站建设有什么百度指数指的是什么
  • 信誉好的东莞网站建设数字营销包括哪六种方式
  • 开发一款游戏app需要多少钱宁波seo推荐优化