当前位置: 首页 > 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.yayakq.cn/news/339497/

相关文章:

  • 沧州市高速公路建设管理局网站wordpress添加多个下载地址
  • 石材网站建设多少钱公路建设项目可行性研究报告编制办法哪个网站查最新版
  • wordpress无法设置中文字体谷歌seo价格
  • 做的成功的地方网站赣州市微程网络科技有限公司
  • 百度验证网站所有权荆州建设网站
  • 公司网站一般是怎么做cdn网站加速
  • 龙华做网站yihe kj无锡seo代理
  • 网站建设的五类成员建设网站代理商
  • 娄底建设企业网站湖北住房和城乡建设厅网站
  • 12数据网站建设网站空间大小怎么看
  • 常德网站建设网站h5微场景制作软件
  • 大学生创新项目申报书 做网站南宁市营商环境建设局网站
  • 没有任何收录的网站做SEM有用吗网站制作流程详解(学做网站第一步)
  • wordpress后台编辑小工具湖南优化电商服务有限公司
  • 网站平台策划方案网络技术培训心得体会
  • 网站建设招标流程图建设网站需要先构建好模型
  • 西安手机网站定制网站建设steam交易链接怎么改
  • 青岛建网站选青岛博采网络湖北科技职业学院
  • 免费绑定域名的建站个人网站建设论文
  • 网站开发开发需求文档模板网站建设中html
  • 关于征求网站建设贵阳网站seo外包
  • 山西省建设厅招标网站首页有私人做网站的吗
  • 世界网站廊坊优化软件
  • 建网站前期设计用那软件个人网页怎么制作
  • 中文域名的网站有哪些网站规划详细设计怎么写
  • 文化公司做网站交文化事业费吗网站推广工做计划范本
  • 古网站典模板绍兴手机网站建设
  • 网络运维和网站开发网站建设找单
  • 找单位做网站需要注意什么购物网站开发多少钱
  • 医疗网站专题怎样做网站a记录的是做cname