剑指offer剪绳子;leetcode:LCR 131. 砍竹子 I

news2024/11/18 14:51:31

现需要将一根长为正整数 bamboo_len 的竹子砍为若干段,每段长度均为正整数。请返回每段竹子长度的最大乘积是多少。

示例 1:

输入: bamboo_len = 12
输出: 81

提示:

  • 2 <= bamboo_len <= 58

注意:本题与主站 343 题相同:. - 力扣(LeetCode)

根据数学经验,绳子一定是各部分分成等分才可能乘出来值最大。

int cuttingBamboo(int bamboo_len) {
    int k = bamboo_len / 2;
    int max = k * (bamboo_len - k);
    int flag = 0;
    if (bamboo_len >= 6) {
        for (int i = 3; i <= bamboo_len / 2; i++) {
            k = (int)(bamboo_len/i);
            long long int p = k;
            for (int j = 0; j < i - 2; j++) {
                p *= k;
            }
            p *= bamboo_len - k * (i - 1);
            if (p > max)
                max = p;
            if (k * i == bamboo_len)
                continue;
            k = (bamboo_len/i)+1;
            p = k;
            for (int j = 0; j < i - 2; j++) {
                p *= k;
            }
            p *= bamboo_len - k * (i - 1);
            if (p > max)
                max = p;
        }
    }
    return max;
}

132:剪绳子二

现需要将一根长为正整数 bamboo_len 的竹子砍为若干段,每段长度均为 正整数。请返回每段竹子长度的 最大乘积 是多少。

答案需要取模 1e9+7(1000000007),如计算初始结果为:1000000008,请返回 1。

示例 1:

输入:bamboo_len = 12
输出:81

提示:

  • 2 <= bamboo_len <= 1000

注意:本题与主站 343 题相同:. - 力扣(LeetCode)

本人一直在写暴力解法

#include <stdio.h>
#include <limits.h>

int cuttingBamboo(int bamboo_len) {
    int k = bamboo_len / 2;
    long long int max = k * (bamboo_len - k);
    int flag = 0;
    long long int max0 = 0;
    long long int max1 = 0;
    long long int MOD = 1000000007;

    if (bamboo_len >= 6) {
        for (int i = 3; i <= bamboo_len / 2; i++) {
            k = bamboo_len / i;
            long long int p = k;
            for (int j = 0; j < i - 2; j++) {
                if (p * k > MOD)
                    flag = 1;
                p = (p * k) % MOD;
            }
            if (p * (bamboo_len - k * (i - 1)) > MOD)
                flag = 1;
            p = (p * (bamboo_len - k * (i - 1))) % MOD;

            if (p > max && flag == 0)
                max = p;
            if (p > max0 && flag == 1)
                max0 = p;
            
            if (k * i == bamboo_len)
                continue;

            k = bamboo_len / i + 1;
            p = k;
            for (int j = 0; j < i - 2; j++) {
                if (p * k > MOD)
                    flag = 2;
                p = (p * k) % MOD;
            }
            if (p * (bamboo_len - k * (i - 1)) > MOD)
                flag = 2;
            p = (p * (bamboo_len - k * (i - 1))) % MOD;

            if (p > max && flag == 0)
                max = p;
            if (p > max1 && flag == 2)
                max1 = p;
        }
    }

    if (flag == 1)
        return max0;
    if (flag == 2) {
        if (max0 > max1)
            return max0;
        else 
            return max1;
    }
    return max;
}

后来看见一个巧解,前2、3、4都可以直接算出结果
从5开始,经过数学推每次分为3结果最大。推导过程参考:LCR 131. 砍竹子 I - 力扣(LeetCode)

int cuttingBamboo(int bamboo_len) {
    if (bamboo_len == 2) {
        return 1;
    }
    if (bamboo_len == 3) {
        return 2;
    }
    if (bamboo_len == 4) {
        return 4;
    }
    long long res = 1;
    while (bamboo_len >= 5) {
        res = (res * 3) % 1000000007;
        bamboo_len -= 3;
    }
    res = (res * bamboo_len) % 1000000007;
    return res;
}

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

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

相关文章

硬件中断错误HardFault_Handle如何解决

一、在硬件中断处点击断点 二、打开Call Stack Window 三、打开Disassembly Window 四、右击空白处&#xff0c;输入遇到硬件中断前地址&#xff0c;即可知道错误原因 程序就会自动跳转硬件中断错误处 ​​​​​​

Python中列表数据的保存与读取:以txt文件为例

目录 引言 一、列表数据的保存 二、列表数据的读取 三、进阶用法与注意事项 1. 处理嵌套列表 2. 处理大量数据 3. 注意事项 四、总结 引言 在Python编程中&#xff0c;我们经常需要处理各种类型的数据&#xff0c;包括列表。列表是一种非常灵活的数据结构&#xff0c;…

天梯赛 L2-052 吉利矩阵

//r[n]:当前第几列的值。 //l[n]:当前第几行的值。 暴力减止 #include<bits/stdc.h> using namespace std; #define int long long const int n1e3; int a,b,c,l[n],r[n],an; void dfs(int x,int y) {if(xb1){an;return ;}for(int i0;i<a;i){l[x]i;r[y]i;if(l[x]&l…

Gateway断言工厂

这个用的时候可以在官网上查

0.5W 3KVDC 隔离单、双输出 DC/DC 电源模块——TPV-W5 3.3V, 5V,12V 15V系列

TPV-W5系列提供正负双输出和单输出&#xff0c;工业级环境温度&#xff0c;用于PCB安装的国际标准结构。此系列产品小巧&#xff0c;效率高&#xff0c;低输出纹波及能承受3000V以上的耐压&#xff0c;用于需要正负电压或单输出和高隔离电压的场合。封装有SIP和DIP可选。

第一届 “帕鲁杯“ writeup

文章目录 MiscMisc-签到江FM 145.8ez_misc为什么我的新猫猫吃不饱 Crypto玛卡巴卡有什么坏心思呢 webWeb-签到 应急响应1.找到JumpServer堡垒机中flag标签的值。2.提交攻击者第一次登录时间。3.提交攻击者源IP。4.提交攻者使用的cve编号。5.提交攻击者留在Web服务器上的恶意程序…

Linux系统-进程和计划任务管理

一.程序和进程 1.程序 保持在硬盘、光盘等介质中的可执行代码和数据文件中静态保存的代码 2.进程 在CPU及内存中运行的程序代码动态执行的代码父、子进程每个程序可以创建一个或多个进程 3.进程特征 动态性&#xff1a;进程是程序的一次执行过程&#xff0c;是临时的&…

使用easyexcel将csv转为excel

一.背景 供应商系统下载的csv文件不支持域控&#xff08;主要是第三方wps服务不能对csv文件加密&#xff0c;但是可以对office系列产品进行权限访问的加密控制&#xff09;。因此思路就改为现将csv文件转为excel文件&#xff0c;然后对excel文件进行加域控制。本文主要介绍如何…

MySQL学习笔记5——函数和索引

函数和索引 一、函数1、数学函数2、字符串函数3、条件判断函数 二、索引1、索引是什么2、单字段索引3、组合索引4、总结 一、函数 MySQL提供了很多功能强大&#xff0c;而且使用起来非常方便的函数&#xff0c;包括数学函数、字符串处理函数和条件判断函数等。 1、数学函数 …

Flink面试(1)

1.Flink 的并行度的怎么设置的&#xff1f; Flink设置并行度的几种方式 1.代码中设置setParallelism() 全局设置&#xff1a; 1 env.setParallelism(3);  算子设置&#xff08;部分设置&#xff09;&#xff1a; 1 sum(1).setParallelism(3) 2.客户端CLI设置&#xff0…

shell简单联系项目

文章目录 推荐一个vscode上的好用的神奇如何使用的方式连接主机的方式配置新主机配置信息启动连接的方式 联系shell 命令的方式读取文件信息设置本地环境变量的方式获取随机数的方式简单案例信息 推荐一个vscode上的好用的神奇 如何使用的方式 连接主机的方式 配置新主机 配置…

运维小技能:nacos部署(外接mysql)

文章目录 I 安装nacos(m1版本)1.1 镜像启动1.2 查看docker容器日志1.3 开启鉴权II 外接mysql的docker部署方式2.1 复制mysql-schema.sql2.2 导入mysql-schema.sqlIII 配置远程用户3.1 创建数据库远程用户3.2 查看远程用户是否有密码I 安装nacos(m1版本) docker search nacos:查…

集成触发器(数电笔记)

同步触发器&#xff1a; 主从触发器&#xff1a; 边沿触发器&#xff1a;

【团体程序设计天梯赛】L2-052 吉利矩阵

思路&#xff1a; 直接回溯枚举每一个位置填的数&#xff0c;二维肯定是不方便的&#xff0c;我们转成一维&#xff0c;下标x从0到n*n-1。二维数组下标从0到n-1&#xff0c;在一维中下标为x的点在二维中对应行是x/n&#xff0c;列是x%n。 每个数最小能填的是0&#xff0c;最大…

一套在线画图工具(突突图 Procviz)

突突图(Procviz)是一款面向跨平台作图平台。支持流程图、思维导图、框架图、组织架构图、ER图、网络拓扑图等。实现了多团体同时协作&#xff0c;实时同步&#xff0c;解决跨地域合作作图的问题。平台提供了丰富的模板和素材库&#xff0c;轻松完成作图&#xff0c;效率翻倍。 …

imx6ull设备树驱动--pinctl、ioctl

添加pinctl节点 进入arch/arm/boot/dts目录下dts文件 在iomuxc下添加pinctlled节点 将 GPIO1_IO03 这个 PIN 复用为 GPIO1_IO03&#xff0c;电气属性&#xff08;配置GPIO一些列寄存器&#xff09;值为 0X10B0 添加led设备节点 与上一节一样&#xff0c;在 / 下面添加设备节…

《AIGC辅助数据分析与挖掘》AIGC助力数据可视化:Excel图形化思维与实施技巧

01 前言 在当今的数据分析中&#xff0c;数据可视化扮演着至关重要的角色。作为一款常用工具&#xff0c;Excel提供了丰富的图形展示功能。利用AIGC&#xff0c;我们可以快速选择合适的图形类型&#xff0c;并进行专业的配置&#xff0c;从而使得数据展示更加吸引人且具有更好…

钟薛高创始人称卖红薯也把债还上:网友,您可千万别……

网红雪糕品牌钟薛高&#xff0c;是真的网红属性强到让所有消费品牌羡慕。 纵使跌落神坛、纵使站在「破产」边缘&#xff0c;依然话题感满满&#xff0c;隔段时间&#xff0c;总能上一个热搜。 比如欠薪上热搜、产品降价上热搜、甚至官网微博微信停更&#xff0c;也得上个热搜&…

VSCode插件开发学习

一、环境准备 0、参考文档&#xff1a;VS Code插件创作中文开发文档 1、大于18版本的nodejs 2、安装Yeoman和VS Code Extension Generator&#xff1a; npm install -g yo generator-code 3、生成脚手架 yo code 选择内容&#xff1a; ? What type of extension do yo…

【1524】java投票管理系统Myeclipse开发mysql数据库web结构java编程计算机网页项目

一、源码特点 java 投票管理系统是一套完善的java web信息管理系统&#xff0c;对理解JSP java编程开发语言有帮助&#xff0c;系统具有完整的源代码和数据库&#xff0c;系统主要采用B/S模式开发。开发环境为TOMCAT7.0,Myeclipse8.5开发&#xff0c;数据库为Mysql5.0&…