国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁(yè) > 學(xué)院 > 開(kāi)發(fā)設(shè)計(jì) > 正文

UVA - 10285 Longest Run on a Snowboard (線性DP)

2019-11-08 02:22:26
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友

        思路:d[x][y]表示以(x, y)作為起點(diǎn)能得到的最長(zhǎng)遞減序列,轉(zhuǎn)移方程d[x][y] = max(d[px][py] + 1),此處(px, py)是它的相鄰位置并且該位置的值小于(x, y)處的值。可以選擇把所有坐標(biāo)根據(jù)值的大小升序排序,因?yàn)?#20540;較大的坐標(biāo)取決于值更小的相鄰坐標(biāo)。

 

AC代碼:

#include<cstdio>#include<algorithm>#include<cstring>#include<utility>#include<string>#include<iostream>#include<map>#include<set>#include<vector>#include<queue>#include<stack>using namespace std;#define eps 1e-10#define inf 0x3f3f3f3f#define PI pair<int, int> const int maxn = 100 + 5;int a[100][100];vector<PI>pos[105];char s[100];int n, m, d[maxn][maxn];const int dx[] = {0,0,-1,1};const int dy[] = {1,-1,0,0}; int solve() {	int ans = 0;	for(int i = 0; i <= 100; ++i) {		int len = pos[i].size();		for(int j = 0; j < len; ++j) {			int x = pos[i][j].first, y = pos[i][j].second;			int v = a[x][y];			d[x][y] = 1;			for(int k = 0; k < 4; ++k) {				int px = x + dx[k], py = y + dy[k];				if(px < 0 || py < 0 || px >= n || py >= m) continue;				if(a[px][py] >= a[x][y]) continue;				d[x][y] = max(d[x][y], d[px][py] + 1);			}			ans = max(ans, d[x][y]);		} 	}	return ans;}int main() {	int T;	scanf("%d", &T);	while(T--) {		for(int i = 0; i <= 100; ++i) pos[i].clear();		scanf("%s%d%d", s, &n, &m);		for(int i = 0; i < n; ++i)			for(int j = 0; j < m; ++j) {				scanf("%d", &a[i][j]);				pos[ a[i][j] ].push_back(make_pair(i, j));			}		PRintf("%s: %d/n", s, solve());	}	return 0;}

如有不當(dāng)之處歡迎指出!


發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 萍乡市| 普宁市| 德安县| 霍林郭勒市| 苏尼特右旗| 靖江市| 鄂尔多斯市| 新兴县| 克什克腾旗| 剑河县| 沭阳县| 耒阳市| 竹溪县| 喀什市| 衡东县| 孟津县| 游戏| 广南县| 德庆县| 廊坊市| 日照市| 庆安县| 湛江市| 壤塘县| 普宁市| 湖州市| 友谊县| 崇礼县| 文山县| 分宜县| 华亭县| 会昌县| 辽源市| 涿鹿县| 丰原市| 凤凰县| 鲜城| 丹凤县| 阜南县| 庆云县| 舟曲县|