Golang每日一练(leetDay0112) 2、3、4的幂

简介: Golang每日一练(leetDay0112) 2、3、4的幂

326. 3的幂 Power of Three

给定一个整数,写一个函数来判断它是否是 3 的幂次方。如果是,返回 true ;否则,返回 false

整数 n 是 3 的幂次方需满足:存在整数 x 使得 n == 3^x

示例 1:

输入:n = 27

输出:true


示例 2:

输入:n = 0

输出:false


示例 3:

输入:n = 9

输出:true


示例 4:

输入:n = 45

输出:false


提示:

  • -2^31 <= n <= 2^31 - 1

进阶:你能不使用循环或者递归来完成本题吗?

代码1:整数限制

基于 3^19 是整数范围内最大的3的幂次方,3^19 = 1162261467

package main
import "fmt"
func isPowerOfThree(n int) bool {
  return n > 0 && 1162261467%n == 0
}
func main() {
  nums := []int{27, 0, 9, 45}
  for _, n := range nums {
    fmt.Printf("%d 是3的幂次方:%t\n", n, isPowerOfThree(n))
  }
}

代码2:

package main
import (
  "fmt"
  "math"
)
func isPowerOfThree(n int) bool {
  if n <= 0 {
    return false
  }
  for n%3 == 0 {
    n /= 3
  }
  return n == 1
}
func main() {
  nums := []int{27, 0, 9, 45}
  for _, n := range nums {
    fmt.Printf("%d 是3的幂次方:%t\n", n, isPowerOfThree(n))
  }
}

输出:

27 是3的幂次方:true

0 是3的幂次方:false

9 是3的幂次方:true

45 是3的幂次方:false

数学公式:

func isPowerOfThree3(n int) bool {
    if n <= 0 {
        return false
    }
    x := math.Log(float64(n)) / math.Log(3)
    return math.Abs(math.Floor(x)-x) < 1e-10
}

342. 4的幂 Power of Four

给定一个整数,写一个函数来判断它是否是 4 的幂次方。如果是,返回 true ;否则,返回 false

整数 n 是 4 的幂次方需满足:存在整数 x 使得 n == 4^x

示例 1:

输入:n = 16

输出:true


示例 2:

输入:n = 5

输出:false


示例 3:

输入:n = 1

输出:true


提示:

  • -2^31 <= n <= 2^31 - 1

进阶:你能不使用循环或者递归来完成本题吗?

代码:

package main
import "fmt"
func isPowerOfFour(n int) bool {
  if n <= 0 {
    return false
  }
  if n&(n-1) != 0 { // 判断是否只有一个1
    return false
  }
  return n&0x55555555 != 0 // 判断1的位置是否为奇数位
}
func main() {
  nums := []int{16, 5, 1}
  for _, n := range nums {
    fmt.Printf("%d 是4的幂次方:%t\n", n, isPowerOfFour(n))
  }
}

输出:

16 是4的幂次方:true

5 是4的幂次方:false

1 是4的幂次方:true

数学公式法:

还是判断x = log(n) / log(4)是否为整数


相关链接

231. 2的幂 Power of Two  🌟

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

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

示例 1:

输入:n = 1

输出:true

解释:2^0 = 1


示例 2:

输入:n = 16

输出:true

解释:2^4 = 16


示例 3:

输入:n = 3

输出:false


示例 4:

输入:n = 4

输出:true


示例 5:

输入:n = 5

输出:false


提示:

  • -2^31 <= n <= 2^31 - 1

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

链接:2的幂 Power of Two


🌟 每日一练刷题专栏 🌟

持续,努力奋斗做强刷题搬运工!

👍 点赞,你的认可是我坚持的动力!

🌟 收藏,你的青睐是我努力的方向!

评论,你的意见是我进步的财富!  

主页:https://hannyang.blog.csdn.net/

Rust每日一练 专栏

(2023.5.16~)更新中...

Golang每日一练 专栏

(2023.3.11~)更新中...

Python每日一练 专栏

(2023.2.18~2023.5.18)暂停更

C/C++每日一练 专栏

(2023.2.18~2023.5.18)暂停更

Java每日一练 专栏

(2023.3.11~2023.5.18)暂停更


目录
相关文章
|
4月前
|
人工智能 监控 安全
智慧工地解决方案,java智慧工地程序代码
智慧工地系统融合物联网、AI、大数据等技术,实现对施工现场“人、机、料、法、环”的全面智能监控与管理,提升安全、效率与决策水平。
132 2
|
2月前
|
安全 Java
Java异常处理:程序世界的“交通规则
Java异常处理:程序世界的“交通规则
320 98
|
4月前
|
安全 Java API
Java中的Lambda表达式:简洁与功能的结合
Java中的Lambda表达式:简洁与功能的结合
438 211
|
4月前
|
JavaScript Java 微服务
现代化 Java Web 在线商城项目技术方案与实战开发流程及核心功能实现详解
本项目基于Spring Boot 3与Vue 3构建现代化在线商城系统,采用微服务架构,整合Spring Cloud、Redis、MySQL等技术,涵盖用户认证、商品管理、购物车功能,并支持Docker容器化部署与Kubernetes编排。提供完整CI/CD流程,助力高效开发与扩展。
504 64
|
3月前
|
存储 数据可视化 Java
Java Stream API 的强大功能
Java Stream API 是 Java 8 引入的重要特性,它改变了集合数据的处理方式。通过声明式语法,开发者可以更简洁地进行过滤、映射、聚合等操作。Stream API 支持惰性求值和并行处理,提升了代码效率和可读性,是现代 Java 开发不可或缺的工具。
Java Stream API 的强大功能
|
4月前
|
前端开发 JavaScript Java
Java 项目实战城市公园信息管理系统开发流程与实用功能实现指南
本系统基于Java开发,采用Spring Boot后端框架与Vue.js前端框架,结合MySQL数据库,构建了一个高效的城市公园信息管理系统。系统包含管理员、用户和保洁人员三大模块,涵盖用户管理、园区信息查询、订票预约、服务管理等功能,提升公园管理效率与服务质量。
162 6
|
4月前
|
安全 Java 数据库
Java 项目实战病人挂号系统网站设计开发步骤及核心功能实现指南
本文介绍了基于Java的病人挂号系统网站的技术方案与应用实例,涵盖SSM与Spring Boot框架选型、数据库设计、功能模块划分及安全机制实现。系统支持患者在线注册、登录、挂号与预约,管理员可进行医院信息与排班管理。通过实际案例展示系统开发流程与核心代码实现,为Java Web医疗项目开发提供参考。
220 2
|
3月前
|
存储 Java 编译器
对比Java学习Go——程序结构与变量
本节对比了Java与Go语言的基础结构,包括“Hello, World!”程序、代码组织方式、入口函数定义、基本数据类型及变量声明方式。Java强调严格的面向对象结构,所有代码需置于类中,入口方法需严格符合`public static void main(String[] args)`格式;而Go语言结构更简洁,使用包和函数组织代码,入口函数为`func main()`。两种语言在变量声明、常量定义、类型系统等方面也存在显著差异,体现了各自的设计哲学。
|
4月前
|
机器学习/深度学习 算法 Java
Java 大视界 -- Java 大数据机器学习模型在生物信息学基因功能预测中的优化与应用(223)
本文探讨了Java大数据与机器学习模型在生物信息学中基因功能预测的优化与应用。通过高效的数据处理能力和智能算法,提升基因功能预测的准确性与效率,助力医学与农业发展。