亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 學院 > 開發設計 > 正文

uva 10564 Paths through the Hourglass

2019-11-10 16:59:44
字體:
來源:轉載
供稿:網友

原題: In the hourglass to the right a path is marked. A path always starts at the first row and ends at the last row. Each cell in the path (except the first) should be directly below to the left or right of the cell in the path in the PRevious row. The value of a path is the sum of the values in each cell in the path. A path is described with an integer representing the starting point in the first row (the leftmost cell being 0) followed by a direction string containing the letters ‘L’ and ‘R’, telling whether to go to the left or right. For instance, the path to the picture is described as ‘2 RRRLLRRRLR’. 這里寫圖片描述 Given the values of each cell in an hourglass as well as an integer S, calculate the number of distinct paths with value S. If at least one path exist, you should also print the path with the lowest starting point. If several such paths exist, select the one which has the lexicographically smallest direction string. Input The input contains several cases. Each case starts with a line containing two integers N and S (2 ≤ N ≤ 20, 0 ≤ S < 500), the number of cells in the first row of the hourglass and the desired sum. Next follows 2N ? 1 lines describing each row in the hourglass. Each line contains a space separated list of integers between 0 and 9 inclusive. The first of these lines will contain N integers, then N ? 1, …, 2, 1, 2, …, N ? 1, N. The input will terminate with N = S = 0. This case should not be processed. There will be less than 30 cases in the input. Output For each case, first output the number of distinct paths. If at least one path exist, output on the next line the description of the path mentioned above. If no path exist, output a blank line instead. Sample Input 6 41 6 7 2 3 6 8 1 8 0 7 1 2 6 5 7 3 1 0 7 6 8 8 8 6 5 3 9 5 9 5 6 4 4 1 3 2 6 9 4 3 8 2 7 3 1 2 3 5 5 26 2 8 7 2 5 3 6 0 2 1 3 4 2 5 3 7 2 2 9 3 1 0 4 4 4 8 7 2 3 0 0 Sample Output 1 2 RRRLLRRRLR 0

5 2 RLLRRRLR

中文: 來自(lucky 貓) 在左邊像沙漏的圖中有一條路徑被標示出來。在沙漏中的路徑總是從最上方開始到最下方結束。當由某列中的某個格子往下列走時只能往左或往右一格。而路徑的值就是經過格子的值的總和。

一條路徑以一個數字以及一連串的動作組成。數字代表此路徑從最上方一列的哪一個格子開始走起(最左方的格子編號為 0)。動作為 R 或 L 其中之一,代表該往右下或左下方走。以左圖中的路徑為例:該路徑為 2 RRRLLRRRLR

給你沙漏中每個格子的值,以及一個數 S,請你算出有多少條路徑的值為S。如果不只一條這樣的路徑存在,輸出最上方列起始位置最小的那條。如果還是不只一條存在,則輸出字典順序最小的那條。

Input

每組測試資料的第一列有2個整數N,S(2 <=N <= 20, 0 <= S < 500)。N代表沙漏中最上方列格子的數目,S代表要求路徑的值。接下來的 2N-1 列描述此沙漏中每一列的情形。每一列中的數字均介於 0 到 9 之間,且以一空白字元相隔。沙漏中各列的格子數分別為N, N-1, …, 2, 1, 2, …, N-1, N.

當N=S=0時代表輸入結束,測試資料的數目不會超過30。請參考Sample Input。

Output

對每組測試資料請輸出2列。 第一列為路徑的數目,第二列為所要求路徑的表示法。如果所要求路徑不存在,第二列請輸出空白列。請參考Sample Output。

#include <bits/stdc++.h>using namespace std;int n,s;long long dp[501][41][41];int hg[41][41];int main(){ ios::sync_with_stdio(false); while(cin>>n>>s,n+s) { for(int i=1;i<=n;i++) for(int j=1;j<=n-i+1;j++) cin>>hg[i][j]; for(int i=n+1;i<2*n;i++) for(int j=1;j<=i-n+1;j++) cin>>hg[i][j]; memset(dp,0,sizeof(dp)); memset(mark,0,sizeof(mark)); for(int i=1;i<=n;i++) dp[hg[2*n-1][i]][2*n-1][i]=1; for(int i=2*n-2;i>=n;i--) { for(int j=1;j<=i-n+1;j++) { for(int k=hg[i][j];k<=s;k++) { dp[k][i][j]+=dp[k-hg[i][j]][i+1][j]; dp[k][i][j]+=dp[k-hg[i][j]][i+1][j+1]; } } } for(int i=n-1;i>=1;i--) { for(int j=1;j<=n-i+1;j++) { for(int k=hg[i][j];k<=s;k++) { dp[k][i][j]+=dp[k-hg[i][j]][i+1][j-1]; dp[k][i][j]+=dp[k-hg[i][j]][i+1][j]; } } } long long ans=0; int start=0; for(int i=1;i<=n;i++) { if(start==0&&dp[s][1][i]!=0) start=i; ans+=dp[s][1][i]; } cout<<ans<<endl; if(0==ans) { cout<<endl; continue; } else { cout<<start-1<<" "; for(int i=1;i<n;i++) { s-=hg[i][start]; if(dp[s][i+1][start-1]) { cout<<'L'; start--; } else cout<<'R'; } for(int i=n;i<2*n-1;i++) { s-=hg[i][start]; if(dp[s][i+1][start]) cout<<'L'; else { cout<<'R'; start++; } } cout<<endl; } } return 0;}

從上往下算(沒算路徑)

#include <bits/stdc++.h>using namespace std;int n,s;long long dp[501][41][41];int hg[41][41];int main(){ ios::sync_with_stdio(false); while(cin>>n>>s,n+s) { for(int i=1;i<=n;i++) for(int j=1;j<=n-i+1;j++) cin>>hg[i][j]; for(int i=n+1;i<2*n;i++) for(int j=1;j<=i-n+1;j++) cin>>hg[i][j]; memset(dp,0,sizeof(dp)); memset(mark,0,sizeof(mark)); for(int i=1;i<=n;i++) dp[hg[1][i]][1][i]=1; for(int i=1;i<=n;i++) { for(int j=1;j<=n-i+1;j++) { for(int k=hg[i][j];k<=s;k++) { dp[k][i][j]+=dp[k-hg[i][j]][i-1][j]; dp[k][i][j]+=dp[k-hg[i][j]][i-1][j+1]; } } } for(int i=n+1;i<2*n;i++) { for(int j=1;j<=i-n+1;j++) { for(int k=hg[i][j];k<=s;k++) { dp[k][i][j]+=dp[k-hg[i][j]][i-1][j]; dp[k][i][j]+=dp[k-hg[i][j]][i-1][j-1]; } } } long long ans=0; for(int i=1;i<=n;i++) { ans+=dp[s][2*n-1][i]; } cout<<ans<<endl; } return 0;}

思路:

類似數塔問題,由于要求路徑數,需要考慮每個數取得以后是否能夠滿足和為固定的s,所以需要記錄s的值,又類似背包的問題。以倒三角威力,對于一個格,可以由左上的格子轉移,也可以又右上的格子轉移,所以狀態轉移方程為(從上往下算hg[i][j]為格子中的數)

dp[s][i][j]+=dp[s-hg[i][j]][i-1][j]+dp[s-hg[i][j]][i-1][j+1] (倒放的三角形) dp[s][i][j]+=dp[s-hg[i][j]][i-1][j]+dp[s-hg[i][j]][i-1][j-1] (正放的三角形)

但是此題不能從上往下算,因為打印路徑的緣故,所以需要從底部往頂部推導。


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产一区二区三区丝袜| 亚洲网站在线观看| 国产精品91一区| 日韩av资源在线播放| 亚洲最大福利网| 91九色在线视频| 国产精自产拍久久久久久| 国产精品久久久久免费a∨| 欧美日本高清视频| 日韩成人在线视频网站| 欧美专区在线视频| 欧美精品免费看| 久久大大胆人体| 国产情人节一区| 欧美日韩国产成人高清视频| 韩国精品久久久999| 中文字幕免费精品一区高清| 亚洲第一视频网| 51精品国产黑色丝袜高跟鞋| 狠狠躁夜夜躁人人躁婷婷91| 国产精品福利久久久| 亚洲奶大毛多的老太婆| 91人成网站www| 亚洲一区二区三区四区在线播放| 国产精品视频网站| 国产男女猛烈无遮挡91| 久久久在线免费观看| 深夜福利一区二区| 国产欧美日韩综合精品| 欧洲中文字幕国产精品| 欧美亚洲激情在线| 国产日韩专区在线| 欧美电影免费在线观看| 精品国产31久久久久久| 欧美野外wwwxxx| 亚洲国产日韩欧美在线99| 欧美亚洲视频在线看网址| 狠狠操狠狠色综合网| 欧美精品久久久久久久久久| 色偷偷av一区二区三区乱| 国产精品嫩草影院久久久| 欧美日在线观看| 国产欧美日韩专区发布| 精品美女永久免费视频| 在线播放日韩欧美| 亚洲美女av在线| 2018日韩中文字幕| 色一情一乱一区二区| www.精品av.com| 亚洲免费视频一区二区| 97国产suv精品一区二区62| 久久久久99精品久久久久| 国产精品久久久久久久电影| 亚洲精品91美女久久久久久久| 亚洲美女av在线| 久99久在线视频| 丰满岳妇乱一区二区三区| 久久精品国产电影| 中文字幕av日韩| 亚洲欧美国产视频| 久久久国产精品视频| 中文字幕亚洲一区在线观看| 国产精品久久久久久久久粉嫩av| 日本精品va在线观看| 97超碰蝌蚪网人人做人人爽| 亚洲最大的网站| 国产91精品久久久久久久| 日韩av中文字幕在线免费观看| 少妇高潮久久久久久潘金莲| 欧美激情久久久久| 亚洲国内精品在线| 久久久久久91| 欧美成人手机在线| 欧美性猛交xxxx富婆弯腰| 亚洲精品日韩在线| 国产一区欧美二区三区| 欧美一级视频免费在线观看| 欧美国产欧美亚洲国产日韩mv天天看完整| 欧美日韩免费一区| 91久久精品国产91性色| 88xx成人精品| 日韩在线免费高清视频| 亚洲免费视频在线观看| 亚洲激情电影中文字幕| 亚洲美女性生活视频| 亚洲欧洲免费视频| 亚洲精品视频二区| 国产精品高潮呻吟久久av无限| 亚洲国产日韩欧美在线图片| 欧美性猛交xxxx富婆| 欧美国产激情18| 亚洲最大成人免费视频| 91av在线网站| 97精品国产97久久久久久| 国内揄拍国内精品| 欧美综合在线第二页| 欧美日韩国产色| 欧美福利在线观看| 菠萝蜜影院一区二区免费| 国产美女精品视频免费观看| 久久中文字幕在线视频| 91精品91久久久久久| 日韩av电影手机在线| 九九热精品视频| 久久精品国产96久久久香蕉| 在线播放国产一区二区三区| 91久久精品美女高潮| 国产99在线|中文| 国自产精品手机在线观看视频| 日本韩国欧美精品大片卡二| 日韩在线免费av| 欧美激情videos| 欧美在线播放视频| 深夜精品寂寞黄网站在线观看| 这里只有视频精品| 日韩av在线播放资源| 欧美日韩免费观看中文| 亚洲免费伊人电影在线观看av| 日韩在线观看网址| 69视频在线免费观看| 国产成人黄色av| 亚洲欧美激情在线视频| 亚洲丝袜一区在线| 亚洲精品一区久久久久久| 精品成人av一区| 久久久亚洲精品视频| 久久免费福利视频| 亚洲人成在线电影| 欧美日韩一区二区在线| 国产精品视频在线播放| 69久久夜色精品国产7777| 午夜精品久久久久久久白皮肤| 狠狠躁夜夜躁久久躁别揉| 国产精品美女www| 色狠狠久久aa北条麻妃| 欧美洲成人男女午夜视频| 最新91在线视频| 亚洲品质视频自拍网| 色综合色综合久久综合频道88| 欧美性jizz18性欧美| 久色乳综合思思在线视频| 亚洲天堂男人的天堂| 国产精品久久9| 26uuu日韩精品一区二区| 日韩美女在线观看| 亚洲精品久久久久久久久久久久| 国产女同一区二区| 九九热r在线视频精品| 亚洲综合成人婷婷小说| 亚洲人成网站在线播| 日本欧美精品在线| 久久久久久久久久久人体| 精品国产一区二区在线| 国产精品国产三级国产aⅴ浪潮| 亚洲国产欧美在线成人app| 欧美激情videoshd| 欧美日韩国产中文字幕| 成人激情春色网| 91av视频在线| 中日韩美女免费视频网站在线观看| 国产精品视频公开费视频| www.欧美精品一二三区| 97人洗澡人人免费公开视频碰碰碰| 欧美性猛交xxxxx水多|