一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - C/C++ - C++計算整數序列的最長遞增子序列的長度操作

C++計算整數序列的最長遞增子序列的長度操作

2021-10-11 10:56na_beginning C/C++

這篇文章主要介紹了C++計算整數序列的最長遞增子序列的長度操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧

給定一個整數序列,計算其中的最長遞增子序列的長度,這是一個典型的動態規劃的算法。

比如8個整數的序列 186 186 150 200 160 130 197 200,最長遞增子序列是 150 160 197 200, 長度為4。

想要解決此問題,可以把這個大問題分解為小問題,依次考慮每個數,計算出包含該數數和該數之前的所有數的最長遞增子序列的長度,計算出的長度值作為該數的對應值記錄下來,最后可以得到這8個數對應的長度值序列,也是8個數,找到這8個數中的最大值就是所有書的最長遞增子序列的長度。

或者也可以這樣想,想要計算8個數的最長遞增子序列的長度有難度,不如先考慮最簡單的情況。只有一個數的時候,最長遞增子序列長度就是1;當有兩個數時,只考慮第一個數和它以前的數的最長遞增子序列就是1,考慮第二個數時只需要找到它之前的所有數中比第二個數小的所有數中最長遞增子序列的長度最大值然后加一 ,就是第二個數的長度。

下面給出實現代碼:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
#include <iostream>
#include <vector>
#include <iterator>
using namespace std;
int findLoogestIncreaseSeq(vector<int> &vect)
{
 int len = 0;
 int *count = new int[vect.size()];
 for (int i = 0; i < vect.size(); i++)
 count[i] = 1;
 for (int i = 0; i < vect.size(); i++)
 {
 for (int j = i - 1; j >= 0; j--)
 {
 if (vect[j] < vect[i] && count[j] >= count[i])
 {
 count[i] = count[j] + 1;
 }
 }
 if (count[i] > len)
 len = count[i];
 }
 delete [] count;
 return len;
}
int main()
{
 vector<int> vect;
 int temp;
 while (cin >> temp)
 {
 vect.push_back(temp);
 }
 cout << findLoogestIncreaseSeq(vect) << endl;
 return 0;
}

補充知識:C++ 求最長遞增子序列(動態規劃)

i 0 1 2 3 4 5 6 7 8
a[i] 1 4 7 2 5 8 3 6 9
lis[i] 1 2 3 2 3 4 3 4 5

時間復雜度為n^2的算法:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
//求最長遞增子序列
//2019/2/28
#include<iostream>
using namespace std;
int LIS(int a[],int N)
{
 int lis[100] = {};
 for(int i =0;i<N;i++)//給每一個數的lis賦初值為1
 {
  lis[i]=1;
 }
 for(int i = 1;i<N;i++)
 {
  for(int j =0;j<i;j++)
  {
   if(a[j]<a[i]&&lis[j]<lis[i]+1) //找出當前元素前面比它小的元素,比較其lis值
    lis[i] = lis[j] + 1;
  }
 }
 int max = lis[0];
 for(int i =1;i<N;i++)
 {
  if(lis[i]>max)
   max = lis[i];   //找出lis數組中最大值,即最長有序子序列的長度
 }
 return max;
}
int main()
{
 int N;
 int a[100];
 while(cin>>N)
 {
  for(int i = 0;i<N;i++)
   cin>>a[i];
  cout<<LIS(a,N)<<endl;
 }
 return 0;
}

以上這篇C++計算整數序列的最長遞增子序列的長度操作就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持服務器之家。

原文鏈接:https://blog.csdn.net/na_beginning/article/details/53611008

延伸 · 閱讀

精彩推薦
  • C/C++C/C++經典實例之模擬計算器示例代碼

    C/C++經典實例之模擬計算器示例代碼

    最近在看到的一個需求,本以為比較簡單,但花了不少時間,所以下面這篇文章主要給大家介紹了關于C/C++經典實例之模擬計算器的相關資料,文中通過示...

    jia150610152021-06-07
  • C/C++學習C++編程的必備軟件

    學習C++編程的必備軟件

    本文給大家分享的是作者在學習使用C++進行編程的時候所用到的一些常用的軟件,這里推薦給大家...

    謝恩銘10102021-05-08
  • C/C++C語言中炫酷的文件操作實例詳解

    C語言中炫酷的文件操作實例詳解

    內存中的數據都是暫時的,當程序結束時,它們都將丟失,為了永久性的保存大量的數據,C語言提供了對文件的操作,這篇文章主要給大家介紹了關于C語言中文件...

    針眼_6702022-01-24
  • C/C++c++ 單線程實現同時監聽多個端口

    c++ 單線程實現同時監聽多個端口

    這篇文章主要介紹了c++ 單線程實現同時監聽多個端口的方法,幫助大家更好的理解和學習使用c++,感興趣的朋友可以了解下...

    源之緣11542021-10-27
  • C/C++C語言實現電腦關機程序

    C語言實現電腦關機程序

    這篇文章主要為大家詳細介紹了C語言實現電腦關機程序,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下...

    xiaocaidayong8482021-08-20
  • C/C++詳解c語言中的 strcpy和strncpy字符串函數使用

    詳解c語言中的 strcpy和strncpy字符串函數使用

    strcpy 和strcnpy函數是字符串復制函數。接下來通過本文給大家介紹c語言中的strcpy和strncpy字符串函數使用,感興趣的朋友跟隨小編要求看看吧...

    spring-go5642021-07-02
  • C/C++深入理解goto語句的替代實現方式分析

    深入理解goto語句的替代實現方式分析

    本篇文章是對goto語句的替代實現方式進行了詳細的分析介紹,需要的朋友參考下...

    C語言教程網7342020-12-03
  • C/C++C++之重載 重定義與重寫用法詳解

    C++之重載 重定義與重寫用法詳解

    這篇文章主要介紹了C++之重載 重定義與重寫用法詳解,本篇文章通過簡要的案例,講解了該項技術的了解與使用,以下就是詳細內容,需要的朋友可以參考下...

    青山的青6062022-01-04
主站蜘蛛池模板: 视频久久精品 | 国产成年人在线观看 | 国产色视频一区二区三区 | 四虎影院在线 | 2019nv天堂香蕉在线观看 | 青青国产精品 | 精品国产综合区久久久久久 | 日本在线播放视频 | 香蕉精品高清在线观看视频 | 日韩一区在线播放 | 涩色网站 | 亚洲第一区欧美日韩精品 | 欧美摘花破处 | 精品国产福利片在线观看 | 天天色综合色 | 猛男深夜狂cao小男生 | 亚洲欧美日韩综合在线播放 | 99热精品成人免费观看 | 国产实拍会所女技师在线 | 亚拍一区| naruto堂同人本子汉化gg | 国产极品精频在线观看 | 91狠狠 | 91大神第九部红酒气质女 | 国产欧美国产精品第一区 | 国产在线精品香蕉综合网一区 | 热门小说同人h改编h | 好大好长好紧爽免费 | 色花堂中文字幕98堂网址 | 精品国产mmd在线观看 | 欧美成人三级伦在线观看 | 成年女人免费 | 深夜视频免费看 | 91精品国产91热久久p | 高清欧美不卡一区二区三区 | 欧美在线观看网址 | 无码乱人伦一区二区亚洲一 | 日本高清不卡一区久久精品 | 亚洲女bbwxxxx另类 | 激情三级hd中文字幕 | 国产成人免费片在线视频观看 |