动态规划之最长上升子序列

问题描述

图1 问题描述1

图2 问题描述2

解题思路

找子问题

图3 解题思路1

图4 解题思路2

确定状态

图5 解题思路3

确定状态转移方程

图6 解题思路4

程序实现

人人为我

#include<iostream>
#include<cstring>
#include<algorithm>
using namespace std;

const int MAXN = 1000;
int s[MAXN];
int f[MAXN];
int n;

int main()
{
    cin >> n;
    memset(s, 0, sizeof(s));//一个字节一个字节地填充
    memset(f,0,sizeof(f));
    for(int i = 0; i < n; i++){
        cin >> s[i];
        f[i]=1;}
    //人人为我
    for(int i = 1; i < n; i++)
        for(int j = 0; j < i; j++)
            if(s[j] < s[i]) f[i] = max(f[i], f[j] + 1);
    cout <<*max_element(f,f+n)<< endl;
    return 0;
}

我为人人

#include<iostream>
#include<cstring>
#include<algorithm>
using namespace std;

const int MAXN = 1000;
int s[MAXN];
int f[MAXN];
int n;

int main()
{
    cin >> n;
    memset(s, 0, sizeof(s));//一个字节一个字节地填充
    memset(f,0,sizeof(f));
    for(int i = 0; i < n; i++){
        cin >> s[i];
        f[i]=1;}
    //我为人人
    for(int i = 0; i < n - 1; i++)
        for(int j = i + 1; j < n; j++)
            if(s[i] < s[j]) f[j] = max(f[j], f[i] + 1);
    cout <<*max_element(f,f+n)<< endl;
    return 0;
}

运行结果

人人为我

图7 运行结果1

我为人人

图8 运行结果2
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 173,663评论 25 708
  • 动态规划(Dynamic Programming) 本文包括: 动态规划定义 状态转移方程 动态规划算法步骤 最长...
    廖少少阅读 3,343评论 0 18
  • “那我要是出了什么问题你会负责么” “负!负责一辈子” “这么小老说一辈子,一辈子太长了” “哪长了,一辈子做好一...
    寻找大米的蚊子阅读 171评论 0 0
  • 登东山而晓鲁,登泰山而晓天下。 由来喜爱登山,却不常行动,所到名山大川,更是少之又少。泰山,就是其一。 多年前初到...
    还不错女士阅读 836评论 2 2
  • 昨天中午回家,妈妈对儿子说“今天是你的生日,生日快乐”!儿子愣了一下才缓过神来,原来今天是他的生日。原本想晚上全家...
    听雨聆声阅读 351评论 0 15