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

哪里有学做ppt的网站网站可以建几个人

哪里有学做ppt的网站,网站可以建几个人,网站博客怎么做,外贸网站建设收款通道文章目录 Tag题目来源题目解读解题思路方法一:公共前缀方法二:n & (n-1) 写在最后 Tag 【位运算】 题目来源 201. 数字范围按位与 题目解读 计算给定区间内所有整数的按位与的结果。 解题思路 本题朴素的方法是直接将区间内的所有整数按位与&…

文章目录

  • Tag
  • 题目来源
  • 题目解读
  • 解题思路
    • 方法一:公共前缀
    • 方法二:n & (n-1)
  • 写在最后

Tag

【位运算】


题目来源

201. 数字范围按位与


题目解读

计算给定区间内所有整数的按位与的结果。


解题思路

本题朴素的方法是直接将区间内的所有整数按位与,时间复杂度为 O ( n ) O(n) O(n),数据量已经达到 1 0 1 0 10^10 1010,必然超时。接下来介绍两种不会超时的方法。

方法一:公共前缀

先来说说什么是公共前缀,公共前缀指的是所有需要按位与计算的数对应的二进制数从高位到低位公共的二进制字符。比如 [9, 12] 的公共前缀为 0000 1,解释如图所示:

根据上图,我们发现连续数字按位与的值等于公共前缀后面再补上剩余的 0。 这个规律正确吗?我们来证明一下。假设对于连续区间内所有数的二进制数,前 i 位(从高位开始数)均相同,第 i+1 位开始不同,由于区间 [m, n] 连续,所以区间内从小到大先枚举出来的数的第 i+1 位为 0,枚举出来相对靠后数的第 i+1 位全部为 1。 并且一定存在连续的两个数 xx+1 满足 x 的第 i+1 位为 0,后面全为 1x+1 的第 i+1 位为 1,后面全为 0,对应上图中的例子即为 1112。这种形如 0111…1000… 的二进制串的按位与的结果一定为 0000…,因此第 i+1 位开始的剩余位均为 0,前 i 位由于均相同,因此按位与结果不变。最后的答案即为二进制字符串的公共前缀再用零补上后面的剩余位。

实现代码

class Solution {
public:int rangeBitwiseAnd(int left, int right) {int res = 0;for (int i = 0; i < 32; ++i) {for (int num = left; num <= right; ++num) {res |= num & 1;num >>= 1;}}return res;}
};

复杂度分析

时间复杂度: O ( l o g n ) O(logn) O(logn) n n nright 的值、

空间复杂度: O ( 1 ) O(1) O(1)

方法二:n & (n-1)

根据方法一,我们知道需要保留的是区间 [m, n] 中的公共前缀,也就是去掉非公共前缀的部分,我们可以使用 n & (n-1) 来去除,直到 m = n,最后返回 n 即可。于是有代码:

实现代码

class Solution {
public:int rangeBitwiseAnd(int m, int n) {while (m < n) {n &= (n-1);}return n;}
};

复杂度分析

时间复杂度: O ( l o g n ) O(logn) O(logn) n n nright 的值、

空间复杂度: O ( 1 ) O(1) O(1)


写在最后

如果文章内容有任何错误或者您对文章有任何疑问,欢迎私信博主或者在评论区指出 💬💬💬。

如果大家有更优的时间、空间复杂度方法,欢迎评论区交流。

最后,感谢您的阅读,如果感到有所收获的话可以给博主点一个 👍 哦。

http://www.yayakq.cn/news/851235/

相关文章:

  • 创建网站的工作流程八年级信息技术什么网站源码做分类信息网站好
  • 网站建设的费用和预算wordpress实现用户中心
  • HS酒店网站建设wordpress代码seo
  • 专门做定制化的网站咸阳兼职做网站
  • 怎样选择高性价比的建站公司北湖区网站建设公司
  • 未来做那个网站致富可以做策略回测的网站
  • 怎么让自己的电脑做网站服务器灰色词排名上首页
  • 邢台口碑好的网站建设网页小游戏4933
  • 12306网站的建设历程略阳县有关作风建设的网站
  • 贵州建站管理系统网站建设的团队分工
  • 朝阳网站制作公司许昌住房建设局的网站
  • 网站制作 台州怎么做网站推广的论文
  • 百度官方网站入口北京网站建设模板
  • 淘客免费网站建设google官方网站注册
  • 网站建设与推广是什么意思广东佛山最新通知
  • 多域名指向同一网站软文优化
  • 深圳物流公司招聘龙岗优化网站建设
  • 山东机关建设网站江苏建设科技网站
  • 设计的网站wordpress更新以后进不去
  • 定制型网站建设价格推荐设计感强的网站
  • 凡科网站可以做seo优化做游戏ppt下载网站有哪些内容
  • 深圳网站建设ppchsjwordpress wp header
  • python 网站建设 拖拽式深圳设计周2021时间
  • 怎么做公司网站需要什么科目简洁大气传媒公司名字
  • 网站搜索页面怎么做服装购物商城网站建设
  • 松江微网站建设鹤城建设集团网站
  • 企业级网站开发项目教程wow做宏的网站
  • 网站跳出率太高互联网营销方式有哪些
  • 企业在阿里云做网站网站怎么做留言
  • 网站建设湛江网站开发邮件服务器