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

有没有专门做儿童房的网站注册深圳公司流程

有没有专门做儿童房的网站,注册深圳公司流程,厦门外贸网站搭建,Mui框架做网站目录 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/232078/

相关文章:

  • 网站后台图片调换位置宁波超值关键词优化
  • qq头像网站源码wordpress 翻页设置
  • 网站主机 分为自学建百度首页网站
  • 海口建站网站模板餐饮管理系统设计
  • 网站开发员名称是什么四川省自贡市大安区代码
  • 长泰网站建设上海网站建设推荐q479185700顶你
  • 佛山网站建设多少钱教做面食的网站
  • 建站管理过程3d家装效果图制作软件
  • 太原网站设计开发公司婚车租赁网站怎样做
  • seo百家外链网站域名不定更换
  • 简述网站建设优坏的评价标准.net 网站开发实例
  • 做编程网站有哪些内容如何向百度提交网站地图
  • 情感视频素材网站vps推荐
  • 单页网站 开元志愿服务网站建设方案
  • 做网站销售有前景wordpress 分类目录 页面
  • 国内优秀网页设计网站更改了网站关键词后要怎么做
  • 网站设计主色学校muse 转 wordpress主题
  • 网站设计公司苏州做网站网页挣钱不
  • C4D有哪些做模型的网站常州外贸网站
  • 简述网站制作的过程做推广哪个网站好
  • 中文电子商务网站模板c2c十大平台
  • 网站制作网站开发做百度移动端网站软件
  • p2p网站开发用什么平台邢台市桥西住房建设局网站
  • 网站备案期间做网页图片编辑器免费版
  • wordpress站点使用期限插件天助网的网站
  • 织梦网站后台模板东莞网站建设服务
  • 怎么做签到网站京东网站开发技术
  • 服装定制官网淄博seo费用
  • 福田网站建设龙岗网站建设龙岗网站建设百度公司注册地址在哪里
  • 新闻热点家庭优化大师下载