「代码比对2」CF149D Coloring Brackets

阳间人的代码:

void SFD(int l,int r){
	if(r==l+1)f[l][r][0][1]=f[l][r][0][2]=f[l][r][1][0]=f[l][r][2][0]=1;
	else{
		if(match[l]!=r){
			SFD(l,match[l]);SFD(match[l]+1,r);
			if(match[l]+1!=match[r]){
				f[l][r][0][0]=f[l][match[l]][0][1]*(f[match[l]+1][r][2][0]+f[match[l]+1][r][0][0])+f[l][match[l]][0][2]*(f[match[l]+1][r][1][0]+f[match[l]+1][r][0][0]);
				f[l][r][1][0]=f[l][match[l]][1][0]*(f[match[l]+1][r][0][0]+f[match[l]+1][r][1][0]+f[match[l]+1][r][2][0]);
				f[l][r][2][0]=f[l][match[l]][2][0]*(f[match[l]+1][r][0][0]+f[match[l]+1][r][1][0]+f[match[l]+1][r][2][0]);
				f[l][r][0][1]=f[l][match[l]][0][1]*(f[match[l]+1][r][2][1]+f[match[l]+1][r][0][1])+f[l][match[l]][0][2]*(f[match[l]+1][r][1][1]+f[match[l]+1][r][0][1]);
				f[l][r][1][1]=f[l][match[l]][1][0]*(f[match[l]+1][r][0][1]+f[match[l]+1][r][1][1]+f[match[l]+1][r][2][1]);
				f[l][r][2][1]=f[l][match[l]][2][0]*(f[match[l]+1][r][0][1]+f[match[l]+1][r][1][1]+f[match[l]+1][r][2][1]);
				f[l][r][0][2]=f[l][match[l]][0][1]*(f[match[l]+1][r][0][2]+f[match[l]+1][r][2][2])+f[l][match[l]][0][2]*(f[match[l]+1][r][1][2]+f[match[l]+1][r][0][2]);
				f[l][r][1][2]=f[l][match[l]][1][0]*(f[match[l]+1][r][0][2]+f[match[l]+1][r][1][2]+f[match[l]+1][r][2][2]);
				f[l][r][2][2]=f[l][match[l]][2][0]*(f[match[l]+1][r][0][2]+f[match[l]+1][r][1][2]+f[match[l]+1][r][2][2]);
				
			}else{
				f[l][r][0][0]=f[l][match[l]][0][1]*f[match[l]+1][r][2][0]+f[l][match[l]][0][2]*f[match[l]+1][r][1][0];
				f[l][r][1][0]=f[l][match[l]][1][0]*(f[match[l]+1][r][1][0]+f[match[l]+1][r][2][0]);
				f[l][r][2][0]=f[l][match[l]][2][0]*(f[match[l]+1][r][1][0]+f[match[l]+1][r][2][0]);
				f[l][r][0][1]=f[match[l]+1][r][0][1]*(f[l][match[l]][0][1]+f[l][match[l]][0][2]);
				f[l][r][1][1]=f[l][match[l]][1][0]*f[match[l]+1][r][0][1];
				f[l][r][2][1]=f[l][match[l]][2][0]*f[match[l]+1][r][0][1];
				f[l][r][0][2]=f[match[l]+1][r][0][2]*(f[l][match[l]][0][1]+f[l][match[l]][0][2]);
				f[l][r][1][2]=f[l][match[l]][1][0]*f[match[l]+1][r][0][2];
				f[l][r][2][2]=f[l][match[l]][2][0]*f[match[l]+1][r][0][2];
			}
		}else{
			SFD(l+1,r-1);
			if(match[l+1]!=r-1){
				f[l][r][1][0]=f[l+1][r-1][0][1]+f[l+1][r-1][2][0]+f[l+1][r-1][0][2]+f[l+1][r-1][0][0]+f[l+1][r-1][2][1]+f[l+1][r-1][2][2];
				f[l][r][2][0]=f[l+1][r-1][0][1]+f[l+1][r-1][1][0]+f[l+1][r-1][0][2]+f[l+1][r-1][0][0]+f[l+1][r-1][1][1]+f[l+1][r-1][1][2];
				f[l][r][0][1]=f[l+1][r-1][1][0]+f[l+1][r-1][0][2]+f[l+1][r-1][2][0]+f[l+1][r-1][0][0]+f[l+1][r-1][1][2]+f[l+1][r-1][2][2];
				f[l][r][0][2]=f[l+1][r-1][1][0]+f[l+1][r-1][0][1]+f[l+1][r-1][2][0]+f[l+1][r-1][0][0]+f[l+1][r-1][1][1]+f[l+1][r-1][2][1];
			}else{
				f[l][r][1][0]=f[l+1][r-1][0][1]+f[l+1][r-1][2][0]+f[l+1][r-1][0][2];
				f[l][r][2][0]=f[l+1][r-1][0][1]+f[l+1][r-1][1][0]+f[l+1][r-1][0][2];
				f[l][r][0][1]=f[l+1][r-1][1][0]+f[l+1][r-1][0][2]+f[l+1][r-1][2][0];
				f[l][r][0][2]=f[l+1][r-1][1][0]+f[l+1][r-1][0][1]+f[l+1][r-1][2][0];
			}
		}
		f[l][r][0][0]%=mol;
		f[l][r][0][1]%=mol;
		f[l][r][0][2]%=mol;
		f[l][r][1][0]%=mol;
		f[l][r][1][1]%=mol;
		f[l][r][1][2]%=mol;
		f[l][r][2][0]%=mol;
		f[l][r][2][1]%=mol;
		f[l][r][2][2]%=mol;
	}
}

longdie的代码:

#include <bits/stdc++.h>
using namespace std;
const int N = 705, mod = 1e9 + 7;
int f[N][N][3][3], match[N];
char s[N];
void dfs(int l, int r) {
	if(l + 1 == r) {
		f[l][r][1][0] = f[l][r][0][1] = 1;
		f[l][r][2][0] = f[l][r][0][2] = 1;
		return;
	}
	if(match[l] == r) {
		dfs(l + 1, r - 1);
		for(int i = 0; i <= 2; ++i) {
			for(int j = 0; j <= 2; ++j) {
				if(i != 1) 
							f[l][r][1][0] += f[l+1][r-1][i][j],
							f[l][r][1][0] %= mod;
				if(j != 1) f[l][r][0][1] += f[l+1][r-1][i][j],
						   f[l][r][0][1] %= mod;
				if(i != 2) f[l][r][2][0] += f[l+1][r-1][i][j],
						   f[l][r][2][0] %= mod;
				if(j != 2) f[l][r][0][2] += f[l+1][r-1][i][j],
						   f[l][r][0][2] %= mod;
			}	
		}
		return;
	}
	register int x = match[l], y = x + 1;
	dfs(l, x), dfs(y, r);
	for(int i = 0; i <= 2; ++i) 
		for(int j = 0; j <= 2; ++j) 
			for(int s = 0; s <= 2; ++s)
				for(int t = 0; t <= 2; ++t) {
					if((s == 1 && t == 1) || (s == 2 && t == 2)) continue;
					f[l][r][i][j] += (1ll*f[l][x][i][s]*f[y][r][t][j]%mod);
					f[l][r][i][j] %= mod;
				}
	
	return;
}
int main() {
	cin >> s + 1;
	int len = strlen(s + 1);
	stack<int> sta;
	for(register int i = 1; i <= len; ++i) {
		if(s[i] == '(') sta.push(i);
		else {
			int x = sta.top(); sta.pop();
			match[x] = i, match[i] = x;
		}
	}
	dfs(1, len);
	int ans = 0;
	for(register int i = 0; i <= 2; ++i)
		for(register int j = 0; j <= 2; ++j) 
			ans = (ans + f[1][len][i][j]) % mod;
	cout << ans << '\n';
	return 0;
}
posted @ 2020-10-27 15:35  _乀aakennes  阅读(103)  评论(2编辑  收藏  举报
levels of contents