欧美大屁股bbbbxxxx,狼人大香伊蕉国产www亚洲,男ji大巴进入女人的视频小说,男人把ji大巴放进女人免费视频,免费情侣作爱视频

歡迎來(lái)到入門(mén)教程網(wǎng)!

C語(yǔ)言

當(dāng)前位置:主頁(yè) > 軟件編程 > C語(yǔ)言 >

C++數(shù)字三角形問(wèn)題與dp算法

來(lái)源:本站原創(chuàng)|時(shí)間:2020-01-10|欄目:C語(yǔ)言|點(diǎn)擊: 次

題目:數(shù)字三角形

題目介紹:如圖所示的數(shù)字三角形,要求從最上方頂點(diǎn)開(kāi)始一步一步下到最底層,每一步必須下一層,求出所經(jīng)過(guò)的數(shù)字的最大和。

輸入:第一行值n,代表n行數(shù)值;后面的n行數(shù)據(jù)代表每一行的數(shù)字。

輸出:經(jīng)過(guò)數(shù)字的最大和。

例:

輸入:

4

1

3 2

4 10 1

4 3 2 20

輸出:

24

分析:這也是一個(gè)典型的貪心算法無(wú)法解決的問(wèn)題,同樣可以用動(dòng)態(tài)規(guī)劃(dp算法)來(lái)解決。把邊界數(shù)字首先初始化到結(jié)果矩陣中,再根據(jù)狀態(tài)方程完成結(jié)果矩陣的遍歷。需要注意的就是數(shù)組不是矩形而是三角形,與傳統(tǒng)的狀態(tài)方程相比需要做點(diǎn)改進(jìn)。

數(shù)組編號(hào):

狀態(tài)方程:p[ i ][ j ]=max{ p[ i-1 ][ j-1 ] , p[ i-1 ][ j ]}

代碼如下:

#include <iostream>
using namespace std;
int main()
{
  int i;
  int n;
  cin >> n;
  int **p = new int *[n];
  for (i = 0; i < n; i++)
  {
    p[i] = new int[n];
  }
  for (i = 0; i < n; i++)
  {
    for (int j = 0; j <= i; j++)
    {
      cin >> p[i][j];
    }
  }
  for (i = 1; i < n; i++)
  {
    p[i][0] += p[i - 1][0];
  }
  for (i = 1; i < n; i++)
  {
    p[i][i] += p[i - 1][i - 1];
  }
  for (i = 2; i < n; i++)
  {
    for (int j = 1; j < i; j++)
    {
      p[i][j] += (p[i - 1][j - 1] > p[i - 1][j]) ? p[i - 1][j - 1] : p[i - 1][j];
    }
  }
  for (i = 0; i < n; i++)
  {
    for (int j = 0; j <= i; j++)
    {
      cout << p[i][j] << " ";
    }
    cout << endl;
  }
}

結(jié)果如下圖:

所以最下層的數(shù)字和最大值是24.

總結(jié)

以上所述是小編給大家介紹的C++數(shù)字三角形問(wèn)題與dp算法,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)歡迎給我留言,小編會(huì)及時(shí)回復(fù)大家的!

上一篇:C語(yǔ)言中的奇技淫巧

欄    目:C語(yǔ)言

下一篇:詳解c/c++賦值函數(shù)(重載=號(hào)運(yùn)算符)

本文標(biāo)題:C++數(shù)字三角形問(wèn)題與dp算法

本文地址:http://mengdiqiu.com.cn/a1/Cyuyan/697.html

網(wǎng)頁(yè)制作CMS教程網(wǎng)絡(luò)編程軟件編程腳本語(yǔ)言數(shù)據(jù)庫(kù)服務(wù)器

如果侵犯了您的權(quán)利,請(qǐng)與我們聯(lián)系,我們將在24小時(shí)內(nèi)進(jìn)行處理、任何非本站因素導(dǎo)致的法律后果,本站均不負(fù)任何責(zé)任。

聯(lián)系QQ:835971066 | 郵箱:835971066#qq.com(#換成@)

Copyright © 2002-2020 腳本教程網(wǎng) 版權(quán)所有