解题思路:
求最长上升序列,动态规划。
注意事项:
条件是只要不是美味度小于前一个就吃的爽,所以是可以等于的。否则会报答案错误27。
参考代码:
n = int(input()) nums = list(map(int,input().split())) dp = [0 for _ in range(n)] maxVal = 0 #求最大上升序列 for i in range(n): dp[i] = 1 for j in range(i): if nums[i] >= nums[j] and dp[i] < (dp[j]+1): dp[i] = dp[j] + 1 if maxVal < dp[i]: maxVal = dp[i] print(maxVal)
0.0分
3 人评分
C语言训练-求1+2!+3!+...+N!的和 (C语言代码)万恶的long long浏览:880 |
简单的a+b (C语言代码)浏览:606 |
字符逆序 (C语言代码)浏览:615 |
C语言程序设计教程(第三版)课后习题9.6 (C语言代码)浏览:587 |
C语言程序设计教程(第三版)课后习题11.1 (C语言代码)浏览:488 |
Pascal三角 (C语言代码)浏览:651 |
盐水的故事 (C语言代码)浏览:1528 |
老王赛马 (C++代码)浏览:905 |
【魔板】 (C++代码)浏览:1160 |
C语言程序设计教程(第三版)课后习题10.1 (C++代码)浏览:502 |