剑指OFFER----面试题14- I. 剪绳子

Posted clown9804

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了剑指OFFER----面试题14- I. 剪绳子相关的知识,希望对你有一定的参考价值。

链接:https://leetcode-cn.com/problems/jian-sheng-zi-lcof/

思路:

  1.假设ni >= 5, 3 * (ni - 3) >= ni ? 3ni - 9 >= ni ? 2ni >= 9

  2.ni = 4, 4 = 2 * 2

  3.2 * 2 * 2 < 3 * 3

-----> 最多划分两个2,其他都是3.

代码:

class Solution {
public:
    int cuttingRope(int n) {
        if (n <= 3) return 1 * (n - 1);
        int res = 1;
        if (n % 3 == 1) res *= 4, n -= 4;
        if (n % 3 == 2) res *= 2, n -= 2;

        while (n) res *=3, n-=3;
        return res;
    }
};

 

以上是关于剑指OFFER----面试题14- I. 剪绳子的主要内容,如果未能解决你的问题,请参考以下文章

leet code 面试题14- I. 剪绳子

leet code 面试题14- I. 剪绳子

剑指 Offer 14- I. 剪绳子

剑指offer面试题 14. 剪绳子

剑指 Offer 14- I. 剪绳子(C++暴力+动态规划贪心解)

[LeetCode]剑指 Offer 14- I. 剪绳子