欧美三区_成人在线免费观看视频_欧美极品少妇xxxxⅹ免费视频_a级毛片免费播放_鲁一鲁中文字幕久久_亚洲一级特黄

UVA - 10118Free Candies(記憶化搜索)

系統(tǒng) 1904 0

題目:UVA - 10118Free Candies(記憶化搜索)


題目大意:給你四堆糖果,每一個(gè)糖果都有顏色。每次你都僅僅能拿隨意一堆最上面的糖果,放到自己的籃子里。假設(shè)有兩個(gè)糖果顏色同樣的話,就行將這對(duì)糖果放進(jìn)自己的口袋。自己的籃子最多僅僅能裝5個(gè)糖果,假設(shè)滿了,游戲就結(jié)束了。問你可以得到的最多的糖果對(duì)數(shù)。


解題思路:這題想了好久,好不easy把狀態(tài)想對(duì)了,結(jié)果腦子發(fā)熱,又偏離了方向。dp【a】【b】【c】【d】:四堆糖果如今在最上面的是哪一個(gè)。由于以下的糖果假設(shè)確定了,那么接下了無論你怎么取,最優(yōu)的肯定是僅僅有一種。所以能夠把如今剩余的糖果的最多數(shù)量加上你之前取的那些糖果你能得到的糖果最多數(shù)量,就是要求的最多的糖果對(duì)數(shù)。

dp【a】【b】【c】【d】 = Max(dp【a + 1】【b】【c】【d】 + 0|1, dp[a][b +1】【c】【d】 + 0|1, dp【a】【b】【c + 1】【d】 + 0|1 , dp【a】【b】【c】【d ?+1] + 0|1).0 | 1取決于你如今籃子里是否有和我取的那個(gè)糖果顏色同樣的。相應(yīng)的籃子里的糖果數(shù)量要變化。假設(shè)數(shù)量等于5了,就說明不能放了,返回0.而且每堆糖果都有最大的數(shù)量,取完也是要結(jié)束的。這些邊界條件要注意.這里發(fā)現(xiàn)了一個(gè)新的知識(shí):用memcpy的時(shí)候假設(shè)不是里面的全部數(shù)據(jù)都要的話,要指明長度,不然可能會(huì)出現(xiàn)錯(cuò)誤。


代碼:

      #include <cstdio>
#include <cstring>

const int N = 42;
const int M = 5;
const int maxn = 1000005;

int candy[N][M];
int top[M];//存放每堆糖果最上面的序號(hào)
int f[N][N][N][N];
int n;

int Max (const int a, const int b) { return a > b ? a: b; }

void init () {

	memset (f, -1, sizeof (f));
	f[n][n][n][n] = 0;//結(jié)束狀態(tài)不論籃子滿不滿
}

bool handle (int r, int c, int k, int *b) {//處理是否有同樣的塘果 int *b是籃子,k + 1是里面有的糖果的個(gè)數(shù)。

	int i;
	for (i = 0; i < k; i++) {

		if (candy[r][c] == b[i])
			break;
	}

	if (!k || i == k) {
		b[k] = candy[r][c];
		return false;
	} else {

		for (int j = i; j < k - 1; j++)
			b[j] = b[j + 1];
		return true;
	}
}

int dfs (int k, int *bket, int a, int b, int c, int d) {

	int bket1[M * 2];
	int& ans = f[a][b][c][d];
	if (k >= M)//籃子滿了
		return 0;//注意這里ans不一定等于0,由于取糖果的順序不同的話,這個(gè)籃子的情況可能不同
	if (ans != -1)
		return ans;
	top[1] = a;
	top[2] = b;
	top[3] = c;
	top[4] = d;
	for (int i = 1; i < M; i++) {

		/*for (int j = 0; j < k; j++)
			bket1[j] = bket[j];*/
		memcpy (bket1, bket, k * sizeof (int));//注意
		/*for (int j = 0; j < k; j++)
			printf ("%d ", bket1[j]);
		printf ("\n");*/
		if (handle (top[i], i, k, bket1)) {

			top[i]++;
			if (top[i] <= n)
				ans = Max (ans, dfs (k - 1, bket1, top[1], top[2], top[3], top[4]) + 1);				
		} else {

			top[i]++;
			if (top[i] <= n)
				ans = Max (ans, dfs (k + 1, bket1, top[1], top[2], top[3], top[4]));
		}
		top[i]--;
	}
	return ans;
}

int main () {

	while (scanf ("%d", &n), n) {

		for (int i = 0; i < n; i++)
			for (int j = 1; j < M; j++)
				scanf ("%d", &candy[i][j]);

		int b[M * 2];
		init ();
		printf ("%d\n", dfs (0, b, 0, 0, 0, 0));
//		printf ("%d\n", f[n][n - 1][0][0]);
/*		for (int i = 0; i < n; i++) {
			for (int j = 0; j < n; j++) {
				for (int k = 0; k < n; k++) {
					for (int l = 0; l < n; l++) 
						printf ("%d ", f[i][j][k][l]);
					printf ("\n");
				}
				printf ("\n");
			}
			printf ("\n");
		}
		printf ("\n");*/
	}
	return 0;
}
    


UVA - 10118Free Candies(記憶化搜索)


更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號(hào)聯(lián)系: 360901061

您的支持是博主寫作最大的動(dòng)力,如果您喜歡我的文章,感覺我的文章對(duì)您有幫助,請(qǐng)用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點(diǎn)擊下面給點(diǎn)支持吧,站長非常感激您!手機(jī)微信長按不能支付解決辦法:請(qǐng)將微信支付二維碼保存到相冊(cè),切換到微信,然后點(diǎn)擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對(duì)您有幫助就好】

您的支持是博主寫作最大的動(dòng)力,如果您喜歡我的文章,感覺我的文章對(duì)您有幫助,請(qǐng)用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會(huì)非常 感謝您的哦!!!

發(fā)表我的評(píng)論
最新評(píng)論 總共0條評(píng)論
主站蜘蛛池模板: 天天干狠狠干 | 2021国产视频| 台湾三级无遮挡在线播放 | 国产精品男人的天堂 | 99精品久久秒播无毒不卡 | a级片在线免费播放 | 欧美一区二区三区四区不卡 | 国产精品第一国产精品 | 九色九色久综色鬼在线 | 亚洲高清一区二区三区 | 国产一级免费视频 | av免费在线观看网站 | 成人一级黄色大片 | 亚洲v日本v欧美v综合v | 五月婷婷狠狠干 | 成年人免费网站视频 | 日本九九精品一区二区 | 99精品国产在热久久 | 边摸边吃奶边做激情叫床 | 国内成人自拍视频 | 一区二区三区高清在线观看 | 久草在线观看首页 | 色六月婷婷 | 性香港xxxxx免费视频播放 | 中文字幕亚洲一区 | 久久华人 | 国产一区精品 | 亚洲午夜一区 | 国产免费观看视频 | www.日日操 | 污视频在线观看网站 | 国产精品成人一区二区1 | 国产亚洲欧美在线 | 天天做天天爱夜夜大爽完整 | 日韩一区二区在线观看视频 | 午夜电影剧场 | 久久久久久久亚洲视频 | 国产探花在线精品一区二区 | 国产精品久久久久久久久久久搜索 | 99精品欧美一区二区三区综合在线 | 欧美激情久久久 |