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

交通运输行业网站建设外贸b2b平台都有哪些网站

交通运输行业网站建设,外贸b2b平台都有哪些网站,澳门响应式网站建设,父亲节ppt模板免费下载文章目录 一. 位运算符脑图二. 相关题目1. 统计二进制数中0的个数2. 数组中只出现一次的数字3. 数组中只出现一次的数字 II4. 不用加减乘除做加法 一. 位运算符脑图 二. 相关题目 1. 统计二进制数中0的个数 解题思路:x & (x-1);它的作用是每次循环…

文章目录

  • 一. 位运算符脑图
  • 二. 相关题目
    • 1. 统计二进制数中0的个数
    • 2. 数组中只出现一次的数字
    • 3. 数组中只出现一次的数字 II
    • 4. 不用加减乘除做加法

一. 位运算符脑图

977ffc91b.png)

二. 相关题目

1. 统计二进制数中0的个数

解题思路:x &= (x-1);它的作用是每次循环把 x 的二进制中从右往左数的最后一位1变成0,直道变成全0为止,循环结束。
在这里插入图片描述

性能分析

  • 时间复杂度:O(1),一般输入的数字都有固定的二进制位数。
  • 空间复杂度:O(1),没有开辟额外的空间。

完整代码

size_t CountOne(int num)
{size_t count = 0;while(x){++count;// 通过这个迭代// 每次可以消除x二进制位中的一个1// 直到x最终为0x = x&(x-1);}return count;
}

2. 数组中只出现一次的数字

题目连接

解题思路

  1. 首先利用异或运算的规律:0异或任何数得到任何数,相同的数异或得0,用0去异或数组中的每一个元素,得到两个只出现一次的数字(我们假设是AB)异或在一起的结果。
  2. 这个结果的二进制中的1,表现的是A和B在这个比特位上的数字是不同的。我们就取从左往右第一个1所在的位数,假设是第3位,接着把原数组分成两组,分组标准是第3位是否为1。如此**,出现两次的数依然会被分到同一个组**,因为相同数字所有位都相同;而不同的数,肯定不在一组。然后把这两个组按照最开始的思路,拿数字0去依次异或,剩余的两个结果就是这两个只出现一次的数字。

性能分析

  • 时间复杂度:O(n)。n为数组的长度。
  • 空间复杂度:O(1)。

完整代码

class Solution 
{
public:void FindNumsAppearOnce(vector<int> data,int* num1,int *num2) {// 数组元素为0或输出型参数为空直接结束if(data.size() == 0 || num1 == nullptr || num2 == nullptr){return;}// 1、算出两个只出现一次的数字异或在一起的结果int ret = 0;for(const auto e : data){ret ^= e;}// 2、计算得到两个只出现一次的数字异或后最高比特位为1的位置int bit = 0;for(int i = 0; i < 32; ++i){if((ret>>i) & 1){bit = i;}}// 3、分成两组分别求出两个只出现一次的数字*num1 = 0;*num2 = 0;for(const auto e : data){if(e & (1<<bit)){*num1 ^= e;}else {*num2 ^= e;}}}
};

3. 数组中只出现一次的数字 II

题目连接

解题思路
首先如果我们不考虑这个只出现一次的数字,那么这个数组中的每一个数字都出现了三次。我们创建一个数组int count[32]去统计所有数的每一位比特位上一共有多少个1,统计结果 count 的每一个元素的值一定是 3n,如果把这个只出现一次的数字也给统计进去,那么 count 的每一个元素的值一定是3n 或 3n+1,根据 count 的每一个元素的值去模3,来还原出只那个出现一次的那个数字。

性能分析

  • 时间复杂度:O(n)。n为数组的长度。
  • 空间复杂度:O(1)。具体应该是数字的二进制位数,但一般输入的数字都有固定的二进制位数。

完整代码

class Solution {
public:int singleNumber(vector<int>& nums) {// 1、统计所有数的每一位比特位上一共有多少个1// 要么3n要么3n+1vector<int> count(32);for(auto& e : nums){for(int i=0; i<32; ++i)// 遍历每一个元素的每一位比特位{if(e & (1<<i)){++count[i];}}}// 2、根据count的结果还原出只出现一次的那个数字int ret=0;for(int i=0; i<32; ++i){if(count[i]%3){ret |= (1<<i);}}return ret;}
};

4. 不用加减乘除做加法

题目连接

解题思路

  • 二进制位异或运算相当于对应位相加,不考虑进位
    比如:
    1 ^ 1 = 0 —> 1 + 1 = 0 (当前位值为0,进一位)
    1 ^ 0 = 1 —> 1 + 0 = 1 (当前位值为1)
    0 ^ 0 = 0 —> 0 + 0 = 0 (当前位值为0)

  • 二进制位与运算相当于对应位相加之后的进位
    比如:
    1 & 1 = 1 —> 1 + 1 = 0 (当前位的值进一位)
    1 & 0 = 0 —> 1 + 0 = 1 (当前位的值不进位)
    0 & 0 = 0 —> 0 + 0 = 0 (当前位的值不进位)

  • 两个数相加:对应二进制位相加的结果 + 进位的结果
    比如:
    3 + 2 --> 0011 + 0010 --> 0011 ^ 0010 + ((0011 & 0010) << 1)
    —> (0011 ^ 0010) ^ ((0011 & 0010) << 1), 当进位之后的结果为0时,相加结束

完整代码

class Solution {
public:int add(int a, int b) {// 进位数为0时,结束循环while(b){// 得到二者和的无进位的结果int notCarry=a^b;// 得到进位数*10的结果b=((unsigned int)(a&b))*2;a=notCarry;}return a;}
};
http://www.15wanjia.com/news/52664.html

相关文章:

  • 张掖做网站公司服装网络营销策划书
  • wordpress修改文章发表日期颜色seo网站优化培训价格
  • 专门做简历的网站有哪些郑州网站公司哪家好
  • 国家工商总局官网求好用的seo软件
  • 做一个网站和手机软件多少钱seo云优化公司
  • 子商务网站建设的一般流程图宁波谷歌优化
  • 网站建设的创意长沙百度搜索排名
  • 做有关兼职网站的需求分析推广方案
  • django 开放api 做网站自己的网站怎么做seo
  • 做网站手机软件网站策划书案例
  • 深圳建设网官方网站营销推广外包公司
  • 网站开发报价表 excel培训计划模板
  • 网站开发连接形式武汉seo排名扣费
  • 如何创建网站设计优化关键词排名
  • 软件开发公司组织结构图seo免费推广软件
  • 怎么免费搭建属于自己的网站盐城seo培训
  • 常熟网站制作南京网站制作
  • 广州建站网络公司黄页网推广服务
  • 做网站需要写代码吗友情链接交换的意义是什么
  • 福州网站建设工作百度竞价推广效果好吗
  • 装修网站php源码seo站外优化最主要的是什么
  • 做网站如何用代码把字体变大湖南靠谱seo优化
  • 徐州工程造价信息网惠州百度seo哪里强
  • 网站制作毕业设计百度怎么找人工客服
  • 截取网站流量上海今天发生的重大新闻
  • 做复印机的模板网站新闻10 30字
  • 身份证被用户做网站备案怎么查权重查询
  • 兰州优化网站推广关键词搜索查询
  • 网站竞品拦截广告怎么做举例说明seo
  • 高端网站建设 深圳优化推广公司哪家好