青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

隨筆 - 87  文章 - 279  trackbacks - 0
<2006年9月>
272829303112
3456789
10111213141516
17181920212223
24252627282930
1234567

潛心看書研究!

常用鏈接

留言簿(19)

隨筆分類(81)

文章分類(89)

相冊

ACM OJ

My friends

搜索

  •  

積分與排名

  • 積分 - 219411
  • 排名 - 118

最新評論

閱讀排行榜

評論排行榜

The Triangle
Time Limit:1000MS  Memory Limit:10000K

Description

7

3 8
8 1 0
2 7 4 4
4 5 2 6 5

(Figure 1)

Figure 1 shows a number triangle. Write a program that calculates the highest sum of numbers passed on a route that starts at the top and ends somewhere on the base. Each step can go either diagonally down to the left or diagonally down to the right.

Input
Your program is to read from standard input. The first line contains one integer N: the number of rows in the triangle. The following N lines describe the data of the triangle. The number of rows in the triangle is > 1 but <= 100. The numbers in the triangle, all integers, are between 0 and 99.

Output
Your program is to write to standard output. The highest sum is written as an integer.

Sample Input

5
7
3 8
8 1 0 
2 7 4 4
4 5 2 6 5

Sample Output

30

Source
IOI 1994

#include<iostream>
using namespace std;

int main()
{
    
int n,digital_num;
    
int result[100][100];
    
int *num;
    
int max = 0;
    
int i,j;
    cin
>>n;
    digital_num 
= n;
    num 
= new int[digital_num];

    
for (i = 0; i<n; i++)
    
{
        
for (j = 0; j<=i; j++)
        
{
            cin
>>num[j];
            
if (i==0)
                result[i][j] 
= num[j];
            
if (i>0)
            
{
                
if (j==0)
                    result[i][j] 
= result[i-1][j]+num[j];
                
if (j==i)
                    result[i][j] 
= result[i-1][j-1]+num[j];
                
if (j>0&&j<i)
                
{
                   
if (result[i-1][j]>result[i-1][j-1])
                       result[i][j] 
= result[i-1][j]+num[j];
                   
else
                       result[i][j] 
= result[i-1][j-1]+num[j];
                }

            }

        }

    }

    
    
for (i = 0; i<n; i++)
        
if (result[n-1][i]>max)
            max 
= result[n-1][i];

    cout
<<max<<endl;
    
return 0;
}
上面是通過的原程序。140k,15MS。


這道題目,過得好辛苦,從開始的遞歸,到遞推加回溯,到窮舉,到窮舉加剪枝,結果就從TLE->TLE->TLE->WA.  一直用著要保留路徑的方法,所以怎么也做不出來,后來換了個思維角度,保存每一步的結果,動態規劃,終于就AC了。做了這題,另我復習了好幾種方法,也對DP有了深得認識,可以說這是搞競賽的好題目,經典,推薦?。?
posted on 2006-02-21 13:09 閱讀(1623) 評論(6)  編輯 收藏 引用 所屬分類: 算法&ACM

FeedBack:
# re: 終于做出了一題IOI了,有點心得。 2006-02-21 20:58 
又忘記 delete []num 了!~~  回復  更多評論
  
# re: 終于做出了一題IOI了,有點心得。 2006-02-25 09:29 imlazy
加油。  回復  更多評論
  
# re: 終于做出了一題IOI了,有點心得。 2006-03-11 11:01 空明流轉
很好啊,再接再厲!
我的動態規劃一直學的不好。。。  回復  更多評論
  
# re: 終于做出了一題IOI了,有點心得。 2006-03-12 11:09 
感謝 空明流轉 的支持!
我已經領略到acm的恐怖了,但是我不會輕易放棄的:)  回復  更多評論
  
# re: 終于做出了一題IOI了,有點心得。 2006-08-12 21:15 Optimistic
加油!  回復  更多評論
  
# re: 終于做出了一題IOI了,有點心得。 2007-05-03 00:27 App
inline int calpos(int row,int col)
{

return row*(row-1)/2+col;
}
int tmem[5051]={-1,7,3,8,8,1,0,2,7,4,4,4,5,2,6,5};
int bestroute[5051]={-1};
int height=5;

int highestroute(int row,int col)
{
if (row>height)
{
return 0;
}
int pos=calpos(row,col);

if (bestroute[pos]>0)
{
return bestroute[pos];
}
int nr[]={1,0,1,1};
int max=0;
int i;
for (i=0;i<4;i+=2)
{
int tmp=highestroute(row+nr[i],col+nr[i+1]);
if (tmp>max)
{
max=tmp;
}
}
max+=tmem[pos];
bestroute[pos]=max;
return max;
}
亂寫的,感覺遞歸邏輯更加清晰:-)  回復  更多評論
  
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
      <noscript id="pjuwb"></noscript>
            <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
              <dd id="pjuwb"></dd>
              <abbr id="pjuwb"></abbr>
              亚洲视频在线一区观看| 亚洲人成网站精品片在线观看| 一区二区高清视频| 欧美日韩性视频在线| 亚洲一级片在线观看| 亚洲一区日韩| 韩国成人精品a∨在线观看| 久久久爽爽爽美女图片| 美女网站久久| 亚洲视频在线播放| 亚洲欧美日韩在线播放| 伊人精品成人久久综合软件| 亚洲成人自拍视频| 欧美丝袜第一区| 久久精品中文字幕一区| 嫩草伊人久久精品少妇av杨幂| 99亚洲精品| 欧美一级专区免费大片| 亚洲激情图片小说视频| 一区二区国产精品| 在线成人免费视频| 亚洲另类黄色| 精品av久久707| 日韩视频在线一区二区| 国产亚洲精品久久久久婷婷瑜伽| 欧美91精品| 国产精品久久9| 欧美粗暴jizz性欧美20| 国产精品夜夜夜| 欧美激情第3页| 国产农村妇女精品| 亚洲美女电影在线| 今天的高清视频免费播放成人| 亚洲伦伦在线| 亚洲国产欧美在线| 亚洲免费视频网站| 一本一本久久a久久精品综合妖精| 欧美一区二区福利在线| 亚洲图片欧洲图片日韩av| 久久久成人精品| 亚洲愉拍自拍另类高清精品| 久久在线视频| 久久久青草婷婷精品综合日韩 | 亚洲精品国久久99热| 国产在线视频不卡二| 日韩午夜免费| 亚洲人永久免费| 久久免费观看视频| 久久电影一区| 国产精品美女www爽爽爽视频| 亚洲高清不卡| 亚洲国产一区在线| 久久午夜精品一区二区| 久久婷婷蜜乳一本欲蜜臀| 国产精品一区二区你懂得 | 久久大逼视频| 国产麻豆9l精品三级站| 99国产精品自拍| 一区二区三区波多野结衣在线观看| 蜜臀av性久久久久蜜臀aⅴ四虎| 久久久亚洲影院你懂的| 国产一区二区日韩精品欧美精品| 亚洲一区在线播放| 欧美与黑人午夜性猛交久久久| 欧美视频免费在线观看| 一本色道久久综合亚洲精品高清 | 国产视频一区二区在线观看 | 美脚丝袜一区二区三区在线观看| 国产日产精品一区二区三区四区的观看方式 | 有坂深雪在线一区| 久久久www成人免费精品| 久久香蕉精品| 亚洲国产美女精品久久久久∴| 久久免费观看视频| 亚洲福利视频专区| 一本色道久久综合狠狠躁篇的优点 | 欧美精品在线极品| aa级大片欧美| 久久成人免费日本黄色| 国语对白精品一区二区| 久久亚洲精品欧美| 亚洲精品欧美一区二区三区| 正在播放亚洲| 国产人久久人人人人爽| 久久综合导航| 亚洲精品一区在线| 欧美一区激情| 91久久精品国产| 国产精品福利在线观看网址| 午夜天堂精品久久久久| 免费人成精品欧美精品| 中国成人亚色综合网站| 国产一区二区三区免费在线观看| 久久伊人一区二区| 亚洲伦伦在线| 久久青青草原一区二区| 日韩一级免费观看| 国产一区二区三区久久 | 亚洲欧美综合| 亚洲高清一区二区三区| 欧美一级一区| 亚洲精品国精品久久99热| 国产精品美女久久久久久2018 | 午夜国产不卡在线观看视频| 女主播福利一区| 亚洲男同1069视频| 亚洲国产一区在线| 国产亚洲福利| 欧美日韩亚洲一区二| 久久久久久久欧美精品| 一区二区三区 在线观看视频| 蜜桃av一区二区三区| 亚洲主播在线| 亚洲日韩欧美视频| 国产日韩欧美在线一区| 欧美日韩免费高清| 美日韩免费视频| 久久国产精品亚洲va麻豆| 9l视频自拍蝌蚪9l视频成人| 欧美激情aaaa| 欧美成年人视频| 久久久久久久成人| 午夜精品久久久99热福利| 日韩视频免费在线| 亚洲激情视频网| 亚洲国产欧美日韩| 红桃视频亚洲| 国产亚洲一区二区在线观看 | 国产精品久久久久一区| 欧美激情bt| 欧美.www| 男女激情久久| 久久综合色综合88| 久久久成人网| 久久全球大尺度高清视频| 欧美一区二区三区免费观看视频| 亚洲图片欧洲图片av| 99国内精品| 一区二区冒白浆视频| 亚洲精选久久| 一本不卡影院| 亚洲小少妇裸体bbw| 亚洲小说春色综合另类电影| 一本色道久久综合亚洲91| 一区二区三区免费看| 99在线热播精品免费| 一区二区成人精品| 亚洲免费在线观看视频| 亚洲一区二区精品视频| 亚洲制服av| 欧美中文字幕在线| 久久青草福利网站| 欧美高清视频一区| 欧美日韩免费观看一区三区 | 欧美精品www在线观看| 欧美精品v日韩精品v国产精品| 欧美精品自拍偷拍动漫精品| 欧美日本精品一区二区三区| 国产精品二区影院| 国产一区二区三区在线观看精品| 国内外成人在线视频| 亚洲黄一区二区| 亚洲网站啪啪| 亚欧美中日韩视频| 美国十次成人| 亚洲毛片视频| 亚洲欧美资源在线| 欧美69视频| 国产精品mv在线观看| 国产一区二区久久精品| 亚洲日韩成人| 欧美中文字幕在线| 欧美国产日本| 亚洲性图久久| 久久久综合网| 国产精品久久久久永久免费观看| 国产亚洲精品久久久| 亚洲美女在线看| 久久国产精品亚洲77777| 亚洲国产片色| 午夜欧美精品| 欧美日韩精品系列| 狠狠干狠狠久久| 亚洲一区二区三区在线| 欧美一级在线视频| 亚洲国产欧美日韩精品| 亚洲欧美日韩国产成人| 欧美国产亚洲视频| 狠狠色狠狠色综合日日tαg| 亚洲一区二区成人在线观看| 欧美h视频在线| 亚洲女女女同性video| 欧美极品aⅴ影院| 国内自拍一区| 午夜精品视频在线| 亚洲黄色在线视频| 久久香蕉精品| 红桃视频亚洲| 亚洲一区二区毛片| 久久综合综合久久综合|