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

个人性质的网站 备注怎么写新浪体育世界杯

个人性质的网站 备注怎么写,新浪体育世界杯,重庆项目信息网,软件制作平台免费目录 1.题目 2.自解 方法1:调用log函数 代码 提交结果 方法2:循环 提交结果 3.优解 方法3:位运算n & (n-1) 0 代码 提交结果 方法4:位运算lowbit 代码 提交结果 4.投机取巧的方法 代码 提交结果 1.题目 https://leetcode.cn/problems/power-of-two/?env…

目录

1.题目

2.自解

方法1:调用log函数

代码

提交结果

方法2:循环

提交结果

3.优解

方法3:位运算n & (n-1) ==0

代码

提交结果

方法4:位运算lowbit

代码

提交结果

4.投机取巧的方法

代码

提交结果


1.题目

https://leetcode.cn/problems/power-of-two/?envType=study-plan-v2&envId=primers-list

给你一个整数 n,请你判断该整数是否是 2 的幂次方。如果是,返回 true ;否则,返回 false

如果存在一个整数 x 使得 n == 2x ,则认为 n 是 2 的幂次方。

 

示例 1:

输入:n = 1
输出:true
解释:20 = 1

示例 2:

输入:n = 16
输出:true
解释:24 = 16

示例 3:

输入:n = 3
输出:false

 

提示:

  • -231 <= n <= 231 - 1

 

进阶:你能够不使用循环/递归解决此问题吗?

2.自解

方法1:调用log函数

cpliusplus网的介绍 点我跳转

3d2d1ea93cde4bcb92f79e59c300f9b7.pnglogarithm n.对数

 注意:

1.作用:log函数默认以e为底,则log(x)返回的是eq?log_e%20x的值.

2.参数x的重要提示:x必须大于0

VS2022运行

#include <math.h>
#include <stdio.h>
int main()
{double m = log(0);printf("%f", m);return 0;
}

运行结果

 ebddf4df40e4491a8f2f5f5cab0d1adf.png

-inf意为eq?-%5Cinfty(infinity)

 将log(0)改为log(-1)再运行

70a3bca3f6454e70b17aa34f77c86734.png

-nan(ind)表示计算结果为非数值(not a number)或无效数值(invalid

代码

***"给你一个整数 n"注意0,-1,-2等也是整数!!!!***

bool isPowerOfTwo(int n) 
{if (n<=0)return 0;int x=(int)(log(n)/log(2)*1.0);//换底公式if (pow(2,x)==n)return true;elsereturn false;
}

提交结果

fbb33f9ea5d745869c94fb28f2dfcd53.png

方法2:循环

bool isPowerOfTwo(int n) 
{if (n<=0)return false;while(n>1){if (n%2)return false;n/=2;}return true;
}

提交结果

23c1f4124d4948858823704d8712bb19.png

3.优解

2的幂的二进制数的特点:只有一个位为1,其余全为0

方法3:位运算n & (n-1) ==0

代码

如果n(n>0)为2的幂,一定满足 n & (n-1) ==0

n & (n-1) 直接将 n 二进制表示的最低位 1 移除,若为2的幂,则运算结果为0

bool isPowerOfTwo(int n) 
{if (n>0 && (n & (n-1)) ==0)return true;elsereturn false;
}

其实可以直接返回逻辑运算的结果

bool isPowerOfTwo(int n) 
{return n>0 && (n & (n-1)) ==0;
}

注意:

1.如果以后if+return可以写成像下面这样,而且返回类型为bool

if (条件)return true;
elsereturn false;

可以简化为

return 条件;

2.如果反过来

if (条件)return false;
elsereturn true;

可以简化为

return !条件;

 

提交结果

77c760602cd2474e9cf5c812f965430a.png

方法4:位运算lowbit

n&(-n) 直接获取 n 二进制表示的最低位的 1

代码

bool isPowerOfTwo(int n) 
{return n>0 && (n==(n&(-n)));
}

提交结果

649349c595944013a9772bc14a040a91.png

4.投机取巧的方法

发现n提供的范围为eq?-2%5E%7B31%7D%20%5Cleq%20n%20%5Cleq%202%5E%7B31%7D%20-%201恰为int范围,其中int范围中最大的2的幂数为0x40000000,用0x40000000%n==0

代码

bool isPowerOfTwo(int n) 
{return n>0 && (0x40000000%n==0);
}

提交结果

dbc98757bcb84b498d90a59329d076d2.png

 

http://www.ritt.cn/news/14549.html

相关文章:

  • 网页制作素材包厉害的seo顾问
  • 盐城哪家做网站的正规今日足球比赛预测推荐分析
  • 泰州网站制作软件网络销售工资一般多少
  • 深圳找网站建设公司搜索引擎营销流程是什么?
  • 海口制作网站葫岛百度seo
  • 网站关键词怎么改今天的国内新闻
  • 行业网站作用优化公司结构
  • 网盘可以做网站空间吗互联网营销师培训内容
  • b2b网络推广大连seo建站
  • 免费发布信息网有哪些网站大数据免费查询平台
  • wordpress一个分类名字app优化
  • 网站建设公司会议网站企业建站公司热线电话
  • html网页设计案例和代码宁波seo推广方式排名
  • 宣城做w网站的公司怎么线上推广自己的产品
  • wordpress自定义字段判断重庆seo网站运营
  • 字体不显示 wordpress百度关键词优化系统
  • 怎么建立网站免费的百度上海推广优化公司
  • 什么是网站名称优帮云首页推荐
  • html做静态网站佛山seo外包平台
  • 做微信推送的网站搜索引擎下载安装
  • wordpress修改秒速苏州网站关键词优化推广
  • 类似知乎可以做推广的网站市场seo是什么
  • 南京做南京华美整容网站企业网络营销推广方法
  • 可以做用户旅程图的网站在运营中seo是什么意思
  • 网站的建设和品牌价值的关系百度域名收录提交入口
  • 免费奖励的网站有哪些友情链接的四个技巧
  • 做英文网站哪里好国外网页模板
  • 专业的龙岗网站建设海外营销推广服务
  • 广州网站建设首选快优搜索引擎的工作原理是什么
  • 网站开发安装平台推广是什么意思