【算法题】剪绳子、计算二进制中1的个数、数值的整数次方

news2024/12/28 19:24:38

剪绳子、计算二进制中1的个数、数值的整数次方

  • 一、剪绳子
    • 1.1、题目描述
    • 1.2、思路
    • 1.3、代码实现:
    • 1.4、华丽的快速幂取余
    • 1.5、小结
  • 二、数值的整数次方
    • 2.1、题目描述
    • 2.2、思路
    • 2.3、代码实现
    • 2.4、小结
  • 三、计算二进制中1的个数
    • 3.1、题目描述
    • 3.2、思路
    • 3.3、代码实现
    • 3.4、小结
  • 总结

一、剪绳子

1.1、题目描述

给你一根长度为 n 的绳子,请把绳子剪成整数长度的 m 段(m、n都是整数,n>1并且m>1),每段绳子的长度记为 k[0],k[1]…k[m-1] 。请问 k[0]k[1]…*k[m-1] 可能的最大乘积是多少?例如,当绳子的长度是8时,我们把它剪成长度分别为2、3、3的三段,此时得到的最大乘积是18。

示例 1:

输入: 2
输出: 1
解释: 2 = 1 + 1, 1 × 1 = 1

示例 2:

输入: 10
输出: 36
解释: 10 = 3 + 3 + 4, 3 × 3 × 4 = 36

来源:力扣(LeetCode)

1.2、思路

利用数学结论,数学上有个常识:当有一定数量的整数数字,若其总和不变,则每个数字之间的差距越小,其所有数字的乘积越大;所以尽可能把 n 均分之后的数字连乘的积会达到最大。不理解?没事,还有一个相同的结论:多边形边越趋于相等总面积越大。

也就是说,把一个数字,尽可能的均分之后数字连乘的积会达到最大。下面直接给出结论,推导过程就略过了。

当子段长度 len=3 时,可以得到最大乘积。因此,应该将给定的正整数拆分成尽可能多的3。根据 n 除以 3 的余数进行分类讨论:

  • 如果余数为 0,即 n=3m(m≥2),则将 n 拆分成 m 个 3;
  • 如果余数为 1,即 n=3m+1(m≥1),由于 2×2>3×1,因此将 n 拆分成 m−1 个 3 和 2 个 2;
  • 如果余数为 2,即 n=3m+2(m≥1),则将 n 拆分成 m 个 3 和 1 个 2。

上述拆分的适用条件是 n≥4。如果 n≤3,则上述拆分不适用,需要单独处理。

  • 如果 n=2,则唯一的拆分方案是 2=1+1,最大乘积是 1×1=1;
  • 如果 n=3,则拆分方案有 3=1+2=1+1+1,最大乘积对应方案 3=1+2,最大乘积是 1×2=2。

这两种情形可以合并为:当 n≤3 时,最大乘积是 n−1。

1.3、代码实现:

class Solution {
public:
    int cuttingRope(int n) {
        if(n<=3)
            return n-1;
        int q=n/3;
        int r=n%3;
        if(r==0)//3*m
            return (int)pow(3,q);
        else if(r==1)//3*m+1=3*(m-1)+2*2;
            return (int)pow(3,q-1)*2*2;
        else//3*m+2
            return (int)pow(3,q)*2;
    }
};

时间复杂度:O(1)。涉及到的操作包括计算商和余数,以及幂次运算,时间复杂度都是常数。

空间复杂度:O(1)。只需要使用常数复杂度的额外空间。

1.4、华丽的快速幂取余

尽可能切多点3,对于最后的切法,要考虑到整体长度。

  • 起码得切2,切1没有意义。
  • 或者切3,即绳子长度刚好可以被 3 整除。
  • 或者切4,比如一直切3,最后余下1的长度,又因为前述提到不要切1,我们可以把前一段3和这一段1,合并起来,切成4。
  • 不能切5,因为可以将5切成 2*3 ,可以得到乘积6。

总结一句话,一直对这段绳子切3,直到最后一个不大于4。为了防止计算的值超出变量类型的返回值,每次都对值进行1000000007取模(参考leetcode)。

代码实现:

class Solution {
public:
    int cuttingRope(int n) {
        if(n<=3)
            return n-1;
        long res=1;
        while(n>4)
        {
            n-=3;
            res=(res%1000000007)*3;
        }
        return (n*res)%1000000007;
    }
};

1.5、小结

数学公式的好处是时间复杂度低。核心是对3取模:

n ≥ 4 n\geq4 n4情况下:

  • n%3==0,结果为 3 n ÷ 2 3^{n\div2} 3n÷2
  • n%3==1,结果为 3 n − 1 × 4 3^{n-1}\times4 3n1×4
  • n%3==2,结果为 3 n ÷ 2 × 2 3^{n\div2}\times2 3n÷2×2

否则结果是n-1。

二、数值的整数次方

2.1、题目描述

实现 n class=“nolink”>pow(x, n) ,即计算 x 的 n 次幂函数(即,xn)。不得使用库函数,同时不需要考虑大数问题。

2.2、思路

分治算法+递归。如果要计算 x 64 x^{64} x64 ,可以按照:x–> x 2 x^{2} x2 --> x 4 x^{4} x4 --> x 16 x^{16} x16 --> x 32 x^{32} x32 --> x 64 x^{64} x64 的顺序,从x 开始,每次直接把上一次的结果进行平方,计算6次就可以得到 x 64 x^{64} x64 的值,而不需要对x 乘63 次 x。

再比如,如果要计算 x 77 x^{77} x77 ,可以按照:x–> x 2 x^{2} x2 --> x 4 x^{4} x4 --> x 9 x^{9} x9 --> x 19 x^{19} x19 --> x 38 x^{38} x38 --> x 77 x^{77} x77 的顺序,可以看到把上一次的结果进行平方后,还要额外乘一个x。

直接从左到右进行推导看上去很困难,因为在每一步中,我们不知道在将上一次的结果平方之后,还需不需要额外乘x。但如果我们从右往左看,分治的思想就十分明显了:

  1. 当要计算 x n x^{n} xn 时,先递归地计算出 y = x n / 2 y=x^{n /2} y=xn/2
  2. 根据递归计算的结果,如果n 为偶数,那么 x n = y 2 x^{n}=y^2 xn=y2 ;如果n为奇数,那么 x n = y 2 × x x^{n}=y^2 \times x xn=y2×x
  3. 递归的边界为 0,任意数的0 次方均为 1。

由于每次递归都会使得指数减少一半,因此递归的层数为O(logn),算法可以在很快的时间内得到结果。

2.3、代码实现

class Solution {
public:
    double quikly(double x, long long n)
    {
        if(n==0)
            return 1.0;
        double cnt=quikly(x,n/2);
        return n%2==0?cnt*cnt:cnt*cnt*x;
    }
    double myPow(double x, int n) {
        long long N=n;
        return N<0?1.0/quikly(x,-N):quikly(x,N);
            
    }
};

2.4、小结

快速幂的本质是分治法。

三、计算二进制中1的个数

3.1、题目描述

编写一个函数,输入是一个无符号整数(以二进制串的形式),返回其二进制表达式中数字位数为 ‘1’ 的个数(也被称为 汉明重量).)。

示例 1:

输入:n = 11 (控制台输入 00000000000000000000000000001011)
输出:3
解释:输入的二进制串 00000000000000000000000000001011 中,共有三位为 ‘1’。

示例 2:

输入:n = 128 (控制台输入 00000000000000000000000010000000)
输出:1
解释:输入的二进制串 00000000000000000000000010000000 中,共有一位为 ‘1’。

示例 3:

输入:n = 4294967293 (控制台输入 11111111111111111111111111111101,部分语言中 n = -3)
输出:31
解释:输入的二进制串 11111111111111111111111111111101 中,共有 31 位为 ‘1’。

来源:力扣(LeetCode)

3.2、思路

计算二进制中1的个数,首先想到位运算;利用位运算的性质加速我们的检查过程,在实际代码中不断右移一位,同时判断当前的最低位是否为1来统计个数。

3.3、代码实现

class Solution {
public:
    int hammingWeight(uint32_t n) {
        int count=0;
        while(n)
        {
            if(n&1)
                count++;
            n>>=1;
        }
        return count;
    }
};

3.4、小结

位运算。

(1)右移运算(>>),正负数的右移处理方式不同:

  • 正数:高位补0,低位溢出的舍去。
  • 负数:高位补1,低位溢出的舍去。
    (2)无符号右移(>>>),无符号右移就是不管是正数还是负数高位补0(跟右移不一样,右移要兼顾正负符号,正数右移补0,负数右移补1,而 “无符号右移” 不区分,一律补0。

总结

一定要做好总结,特别是当没有解出题来,没有思路的时候,一定要通过结束阶段的总结来反思犯了什么错误。解出来了也一定要总结题目的特点,题目中哪些要素是解出该题的关键。不做总结的话,花掉的时间所得到的收获通常只有 50% 左右。

在题目完成后,要特别注意总结此题最后是归纳到哪种类型中,它在这种类型中的独特之处是什么。

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/686201.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Kafka最基础使用

一、概念 2、应用场景 异步处理系统解耦流量削峰日志处理 3、消息队列的两种模式 点对点模式 消息发送者生产消息发送到消息队列中&#xff0c;然后消息接收者从消息队列中取出并且消费消息。消息被消费以后&#xff0c;消息队列中不再有存储&#xff0c;所以消息接收者不可…

(一)CSharp-网络编程

一、OSI 参考模型 &#xff08;1&#xff09;物理层 作为原始的位流或电气处理。 &#xff08;2&#xff09;数据链路层 负责建立、维持和释放数据链路的连接。 &#xff08;3&#xff09;网络层 选择合适的网间路由和交换结点&#xff0c;以确保数据及时传送。网络层将数据…

Flutter性能优化的一些路径思考

不可否认 Flutter 是一个非常强大的移动应用开发框架&#xff0c;我们在技术架构选型时就是选用的 Flutter&#xff0c;特别是跨端能力属实很优秀&#xff0c;but 也逐渐发现在复杂的应用程序实现中&#xff0c;App 的性能会受到一些影响。 其实这个问题&#xff0c;我们内部…

如何用Dialog DA1468X DK PRO测试其他板子的电流

2021.09.27 Jim 目录 工具准备... 1 PC上位机安装... 1 打开PC上位机... 1 消除DA1468X开发板本身底电流... 2 测试待测板子的功耗... 3 电压调节... 4 跳线帽... 6 工具准备 DA1468X DK PRO开发板一套&#xff0c;不需要装顶板的小板子&#xff0c;只需要母板&#…

「缤纷色彩的饼状图」:通过使用matplotlib库绘制饼状图,让读者期待在这个色彩缤纷的图表中探索数据的美丽。

嘿&#xff0c;大家好&#xff01;今天我要带你们探索一个有趣的话题&#xff1a;使用matplotlib库绘制饼状图。虽然这听起来可能有些复杂&#xff0c;但我会用轻松幽默的语言给大家讲解&#xff01;准备好了吗&#xff1f;让我们开始吧&#xff01; 首先&#xff0c;我们需要导…

人工智能的奥秘:机器学习的各大门派

本篇文章是博主在人工智能等领域学习时&#xff0c;用于个人学习、研究或者欣赏使用&#xff0c;并基于博主对人工智能等领域的一些理解而记录的学习摘录和笔记&#xff0c;若有不当和侵权之处&#xff0c;指出后将会立即改正&#xff0c;还望谅解。 文章分类在学习摘录和笔记专…

2023网络安全 -- 正向连接与反向连接

一、正向连接&#xff0c;Linux服务器主动控制windows服务器 1、上传nc到windows服务器上运行 2、以管理员身份运行cmd 3、执行下面命令&#xff0c;监听任意来自8899端口的数据&#xff0c;等待服务器来连接 nc -e cmd -lvvp 8899 4、Linux服务器执行如下命令&#xff0c;i…

解决USB设备PC不识别问题思路(亲测方案)

前言&#xff1a; 因环境是集控封锁USB端口的&#xff0c;所以刚碰到用户出现此问题&#xff0c;一般都认为是策略封堵拒绝了&#xff0c;但经过后面测试及权限查看是没问题的&#xff0c;所以深究一看&#xff0c;完全是USB设备都没有被PC主机识别的问题。按常规我们一般碰到这…

渗透怎么学?渗透测试中超全的提权思路来了!

提权Webshell&#xff1a;尽量能够获取webshell&#xff0c;如果获取不到webshell可以在有文件上传的地方上传反弹shell脚本&#xff1b;或者利用漏洞&#xff08;系统漏洞&#xff0c;服务器漏洞&#xff0c;第三方软件漏洞&#xff0c;数据库漏洞&#xff09;来获取shell。 …

webpack3 打包vue项目导致app体积过大

问题说明&#xff1a;打包导致 js 很大&#xff0c;然后访问特别慢。 Q&#xff1a;如果你的 js 达到了好几M&#xff0c;&#xff08;除了个别情况&#xff0c;比如的代码量真的超级大到不行&#xff0c;其实这个本身就不成立&#xff09;。我最开始就是&#xff0c;打包了我…

CSDN个性化推荐系统-负反馈测试

文章目录 前言一、uc不感兴趣标签过滤测试1.uc不感兴趣标签获取(uc_unlike_tag_list)1.1个人中心界面1.2从标签中可以发现什么&#xff1f;1.3与研发确认点1.4设计开发1.5接口获取结果 2.推荐流文章标签获取(tag_list)2.1部分代码2.2基本标签校验2.3基本标签校验结果 3.推荐流u…

Linux——DNS域名解析服务

个人简介&#xff1a;云计算网络运维专业人员&#xff0c;了解运维知识&#xff0c;掌握TCP/IP协议&#xff0c;每天分享网络运维知识与技能。座右铭&#xff1a;海不辞水&#xff0c;故能成其大&#xff1b;山不辞石&#xff0c;故能成其高。 个人主页&#xff1a;小李会科技的…

【③MySQL 数据查询】:提高查询的效率

前言 ✨欢迎来到小K的MySQL专栏&#xff0c;本节将为大家带来MySQL数据查询的讲解&#xff08;基本、分组、排序、聚合、分页、条件查询&#xff09; 目录 前言一、基本查询二、条件查询三、聚合函数(统计函数)四、分组查询五、排序查询五、分页查询六、总结 一、基本查询 MySQ…

海格里斯HEGERLS仓储设备高端定制|四向穿梭车立体库仓储的重要设备换层提升机

随着科技的快速发展&#xff0c;仓储物流行业已慢慢的朝着无人化、自动化和智能化方向快速发展&#xff0c;用户的需求量也随之日益提升。自动化立体库早已成为很多企业智能仓的标配&#xff0c;可以实现仓库高层合理化、存取自动化、操作简便化。在立体仓库内&#xff0c;高位…

基于SQL Server数据库的安全性对策探究

数据库进阶课程论文 题 目&#xff1a;基于SQL Server数据库的安全性对策探究 作者姓名&#xff1a; 作者学号&#xff1a; 专业班级&#xff1a; 提交时间&#xff1a; 2023/6/4 目 录 1概述 1 2 SQL Server数据库的安全问题 1 2&#xff0e;1以使用者身份进入数据库 1 2&a…

区块链中怎么惩罚虚假信息的矿工,工作量证明POW,共识算法

目录 区块链中怎么惩罚虚假信息的矿工 工作量证明POW 什么是工作量证明&#xff1f; 现在出现了另一个问题&#xff1a;如果其他人偷看了小明的答案并且抢答了怎么办&#xff1f; 为什么区块可以安全广播&#xff1f; 共识算法 小结 区块链中怎么惩罚虚假信息的矿工 1…

二叉树|代码随想录2刷|11-34

222.完全二叉树的节点个数 链接&#xff1a;力扣 利用完全二叉树的性质&#xff0c;这个更容易想到&#xff0c;如何计算完全二叉树的节点数 | labuladong 的算法小抄 另一个二分的方法计算太偏了&#xff0c;既然时间复杂度都是O&#xff08;logn*logn&#xff09;&#xff0c…

Python读写xml(xml,lxml)Edge 浏览器插件 WebTab - 免费ChatGPT

Python读写xml&#xff08;xml&#xff0c;lxml&#xff09;Edge 浏览器插件 WebTab - 免费ChatGPT XML一、xml文件创建方法一&#xff1a;使用xml.dom.minidom1、文件、标签的创建 方法二&#xff1a;使用ElementTree 二、xml文件修改1、修改标签内容&#xff0c;属性2、增加子…

flask旅游数据可视化-计算机毕设 附源码81319

flask旅游数据可视化 摘要 信息化社会内需要与之针对性的信息获取途径&#xff0c;但是途径的扩展基本上为人们所努力的方向&#xff0c;由于站在的角度存在偏差&#xff0c;人们经常能够获得不同类型信息&#xff0c;这也是技术最为难以攻克的课题。针对旅游数据可视化等问题&…

阿里企业邮箱标准版、集团版和尊享版有什么区别?

阿里云企业邮箱版本分为免费版、标准版、集团版和尊享版&#xff0c;除了费用区别&#xff0c;功能方面有什么差异&#xff1f;如何选择企业邮箱版本&#xff1f;免费版0元适合初创型企业&#xff0c;标准版适合大、中、小型企业使用&#xff0c;涉及子公司之间邮箱通讯可以选择…