⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 3056.txt

📁 北大ACM题目例程 详细的解答过程 程序实现 算法分析
💻 TXT
字号:
Source

Problem Id:3056  User Id:fzk 
Memory:4008K  Time:3328MS
Language:G++  Result:Accepted

Source 

#include <stdio.h>

int a[1010];
int n;
int ans[1010][1010];

int main( ) {
	int t, i, j, l, k, temp;
	scanf( "%d", &t );
	while( t-- ) {
		scanf( "%d", &n );
		
	
		for( i=0; i<n; i++ ) {
			scanf( "%d", &a[i] );
		}

		for( i=0; i<n; i++ ) {
			ans[i][i] = ans[i][i+1] = 0;
		}

		for( l=2; l<=n; l+=2 ) {
			for( i=0; i+l<=n; i++ ) {
				j = i+l;
				ans[i][j] = 0;
				for( k=i+1; k<j && ans[i][j] < j-i; k+=2 )
					if( ( temp = ans[i+1][k] + ans[k+1][j] + (a[i]==a[k]) ) > ans[i][j] )
						ans[i][j] = temp;
			}
		}

		printf( "%d\n", ans[0][n] );
	}
	return 0;
}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -