题解 | #汽水瓶#

汽水瓶

https://www.nowcoder.com/practice/fe298c55694f4ed39e256170ff2c205f

#include <stdio.h>
//使用动态规划解决问题
int maxnum(int a)
{
    int res=0,i=2;
    int dp[500];
    dp[1]=a/3+a%3;
    res=a/3;
    for(i=2;dp[i-1]>1;i++)
        if(dp[i-1]>2)
        {
            dp[i]=dp[i-1]/3+dp[i-1]%3;
            res+=dp[i-1]/3;
        } else if(dp[i-1]==2)
        {
            dp[i]=1;
            res+=1;
        }
    
    return res;
}

int main() {
    int num,flag=0;
    while (scanf("%d", &num) != EOF) {  
        if(num!=0)
        {
            flag = maxnum(num);
            printf("%d\n",flag);
        }
        
    }
    return 0;
}

解题思路:

可以将换汽水瓶分为i次兑换,设dp[i]为第i次兑换后剩余的空汽水瓶数。而第i次兑换后所剩的空汽水瓶数依赖于第i-1次所剩的空汽水瓶数。这样就能得到一个状态转移方程式(dp[i]=1作为临界条件):

dp[1]=原始空汽水瓶数量m/3;

当dp[i-1]>2时,

dp[i]=dp[i-1]/3+dp[i-1]%3;

当dp[i-1]=2

dp[i]=1

然后使用一个变量res来统计可兑换的汽水数量。

#算法刷题#
全部评论

相关推荐

不愿透露姓名的神秘牛友
11-27 10:28
点赞 评论 收藏
分享
喜欢走神的孤勇者练习时长两年半:池是池,发是发,我曾池,我现黑
点赞 评论 收藏
分享
我已成为0offer的糕手:别惯着,胆子都是练出来的,这里认怂了,那以后被裁应届被拖工资还敢抗争?
点赞 评论 收藏
分享
评论
点赞
收藏
分享
正在热议
# 25届秋招总结 #
442405次浏览 4511人参与
# 春招别灰心,我们一人来一句鼓励 #
41942次浏览 531人参与
# 北方华创开奖 #
107430次浏览 599人参与
# 地方国企笔面经互助 #
7961次浏览 18人参与
# 同bg的你秋招战况如何? #
76670次浏览 561人参与
# 虾皮求职进展汇总 #
115499次浏览 886人参与
# 阿里云管培生offer #
120224次浏览 2219人参与
# 实习,投递多份简历没人回复怎么办 #
2454658次浏览 34857人参与
# 实习必须要去大厂吗? #
55771次浏览 961人参与
# 提前批简历挂麻了怎么办 #
149901次浏览 1977人参与
# 投递实习岗位前的准备 #
1195935次浏览 18548人参与
# 你投递的公司有几家约面了? #
33205次浏览 188人参与
# 双非本科求职如何逆袭 #
662208次浏览 7394人参与
# 如果公司给你放一天假,你会怎么度过? #
4753次浏览 55人参与
# 机械人春招想让哪家公司来捞你? #
157628次浏览 2267人参与
# 如果你有一天可以担任公司的CEO,你会做哪三件事? #
11561次浏览 287人参与
# 发工资后,你做的第一件事是什么 #
12704次浏览 62人参与
# 工作中,努力重要还是选择重要? #
35804次浏览 384人参与
# 参加完秋招的机械人,还参加春招吗? #
20126次浏览 240人参与
# 我的上岸简历长这样 #
452016次浏览 8088人参与
# 实习想申请秋招offer,能不能argue薪资 #
39299次浏览 314人参与
# 非技术岗是怎么找实习的 #
155866次浏览 2120人参与
牛客网
牛客企业服务