当前位置: 首页 > 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.ds6.com.cn/news/90548.html

相关文章:

  • 商业网站设计方案模板电商网站设计论文
  • 服务器 网站建设营销推广软文案例
  • 南昌企业网站模板建站海外网站seo优化
  • 用哪个软件做网站网站推广计划方案
  • 巴中做网站公司seo网络优化软件
  • 做爰全国网站网站制作定制
  • 做网站用那种数据库国内最好的seo培训
  • 长沙网站建设服务公司百度教育
  • 福州网页成品网站源码的优化技巧
  • 装饰网站方案游戏推广员拉人犯法吗
  • wordpress mxtheme02seo排名课程咨询电话
  • html5网页代码天津seo结算
  • 供应链管理六大模块二级域名和一级域名优化难度
  • 推广一个网站需要什么学技术包分配的培训机构
  • wordpress flash主题seo的培训班
  • 如何做新闻源网站如何进行网站制作
  • wordpress 归档页面地址广州搜索排名优化
  • 怎么做这个购物网站独立网站和平台网站
  • 有没有做培养基的网站辅导班培训机构
  • h5网站设计报价百度推广账号注册
  • 动漫制作专业好吗汕头seo不错
  • wordpress菜单栏添加页面正规seo排名多少钱
  • 电子商务网站建设的平台1688seo优化是什么
  • html5移动网站开发实践申泽seo
  • 织梦菜谱网站模板免费下载自媒体135的网站是多少
  • 在线播放网站建设深圳百度推广公司
  • 泉州做网站工作室武汉网络推广seo
  • 广州乐地网站建设抖音seo教程
  • 公司网站404中山seo
  • 深圳做网站哪家专业十大看免费行情的软件下载