| 记录编号 | 253464 | 评测结果 | AAAAAAAAAA | 
    
        | 题目名称 | 1180.机器分配 | 最终得分 | 100 | 
    
        | 用户昵称 |  Go灬Fire | 是否通过 | 通过 | 
    
        | 代码语言 | C++ | 运行时间 | 0.037 s | 
    
        | 提交时间 | 2016-04-22 10:39:27 | 内存使用 | 0.60 MiB | 
    
    
    
    		显示代码纯文本
		
		#include<cmath>
#include<cstdio>
#include<algorithm>
#include<cstring>
using namespace std;
const int maxn=200;
int f[maxn][maxn],a[maxn][maxn],s[maxn][maxn],c[maxn];
void Init();
void Print(int,int);
int main(){
	freopen("machinea.in","r",stdin);
	freopen("machinea.out","w",stdout);
	Init();
	return 0;
}
void Init(){
	int n,m;
	scanf("%d%d",&m,&n);
	for(int i=1;i<=n;i++){
		for(int j=1;j<=m;j++){
			scanf("%d",&a[i][j]);
		}
	}
/*	for(int i=1;i<=m;i++){
		for(int j=1;j<=n;j++){
			printf("a[%d][%d]=%d\n",i,j,a[i][j]);
		}
	}*/
	for(int i=1;i<=n;i++){
		for(int j=1;j<=m;j++){
			for(int k=0;k<=j;k++){
				f[i][j]=max(f[i][j],f[i-1][j-k]+a[i][k]);
				if(f[i][j]==f[i-1][j-k]+a[i][k])s[i][j]=k;
				//printf("%d %d k=%d\n",i,j,k);
				//s[i][j]=
			}
		}
	} 
	printf("%d\n",f[n][m]);
	//Print(n,m);
}
void Print(int i,int j){
	if(i==0 || j==0)return ;
	Print(i-1,j-s[i][j]);
	printf("%d %d\n",i,s[i][j]);
}