leetcode day33 738+343

738 单调递增的数字

当且仅当每个相邻位数上的数字 xy 满足 x <= y 时,我们称这个整数是单调递增的。

给定一个整数 n ,返回 小于或等于 n 的最大数字,且数字呈 单调递增

示例 1:

复制代码
输入: n = 10
输出: 9

示例 2:

复制代码
输入: n = 1234
输出: 1234

示例 3:

复制代码
输入: n = 332
输出: 299

c 数字转字符串库函数

sprintf(str,"%d",num), 头文件<stdio.h>

int num = 123;

char str[100];

sprintf(str, "%d", num);

printf("%s\n", str); // 输出 "123"

字符串转数字atoi(str)

贪心策略:从后往前遍历,如果s[i]<s[i-1],标记该位置,后面的数字变为9,s[i-1]-=1

例如332,s[2]<s[1],那么

i=2:s[1]-1=2,loc=2,322

i=1:s[0]-1=2,loc=1299

cs 复制代码
int monotoneIncreasingDigits(int n) {
    char s[11]={};
    sprintf(s,"%d",n);
    int loc=0;//从loc开始后面的数字全变为9
    int i,len=strlen(s),flag=1;
    for(i=len-1;i>0;i--){
        if(s[i]<s[i-1]){
            loc=i;
            flag=0;//flag=0表示有需要修改的
            s[i-1]-=1;
        }
    }
    for(i=loc;i<len&&flag==0;i++){
        s[i]='9';
    }
    return atoi(s);
}

343 整数拆分

给定一个正整数 n ,将其拆分为 k正整数 的和( k >= 2 ),并使这些整数的乘积最大化。

返回 你可以获得的最大乘积

示例 1:

复制代码
输入: n = 2
输出: 1
解释: 2 = 1 + 1, 1 × 1 = 1。

示例 2:

复制代码
输入: n = 10
输出: 36
解释: 10 = 3 + 3 + 4, 3 × 3 × 4 = 36。

1、确定dp[i]的含义:拆分i的最大值

2、初始化 dp[2]=1

3、确定动规方程

dp[i]有两种来源,划分为2种j*(i-j)和两种以上j*dp[i-j]

例如dp[6]=3*3、3*dp[3]=3*2

显然dp[i]要在这里面取最大值

所以动规方程为dp[i]=max(dp[i],max(j*dp[i-j],j*(i-j)));

cs 复制代码
int dp[60]={};
int max(int a,int b){
    return a>b?a:b;
}
int integerBreak(int n) {
    dp[2]=1;
    for(int i=3;i<=n;i++){
        for(int j=1;j<=i/2;j++){
            //动规方程
            dp[i]=max(dp[i],max(j*dp[i-j],j*(i-j)));
        }
    }
    return dp[n];
}
相关推荐
chengooooooo17 分钟前
leetcode Top100 238. 除自身以外数组的乘积|数组系列
算法·leetcode
安木夕2 小时前
C#-Visual Studio宇宙第一IDE使用实践
前端·c#·.net
GalaxyPokemon4 小时前
LeetCode - 53. 最大子数组和
算法·leetcode·职场和发展
hn小菜鸡4 小时前
LeetCode 1356.根据数字二进制下1的数目排序
数据结构·算法·leetcode
zhuiQiuMX4 小时前
分享今天做的力扣SQL题
sql·算法·leetcode
gregmankiw5 小时前
C#调用Rust动态链接库DLL的案例
开发语言·rust·c#
阿蒙Amon6 小时前
06. C#入门系列【自定义类型】:从青铜到王者的进阶之路
开发语言·c#
全栈凯哥7 小时前
Java详解LeetCode 热题 100(26):LeetCode 142. 环形链表 II(Linked List Cycle II)详解
java·算法·leetcode·链表
全栈凯哥7 小时前
Java详解LeetCode 热题 100(27):LeetCode 21. 合并两个有序链表(Merge Two Sorted Lists)详解
java·算法·leetcode·链表
SuperCandyXu7 小时前
leetcode2368. 受限条件下可到达节点的数目-medium
数据结构·c++·算法·leetcode