64,661
社区成员
发帖
与我相关
我的任务
分享
#include<iostream>
#include<cmath>
using namespace std;
int n;
const int **a;
void sol1(int c,int d,int x)
{
for(int i=c;i<c+x;i++)
{
for(int j=d;j<d+x;j++)
{
a[i][j]*=-1;
}
}
}
void solve(int c,int d,int x)
{
int sum1=0;
int sum2=0;
if(c>n-x) return ;
for(int i=c;i<c+x;i++)
{
for(int j=d;j<d+x;j++)
{
if(a[i][j]<0)
sum1+=a[i][j];//负数和
if(a[i][j]>0)
sum2+=a[i][j];//正数和
}
}
if(sum1+sum2>=0)
{
if(d<n-x)
solve(c,d+1,x);
else solve(c+1,0,x);
}
if(sum1+sum2<0)
{
sol1(c,d,x);
if(d<n-x)
solve(c,d+1,x);
else
solve(c+1,0,x);
}
}
int main()
{
int sum=0;
cin>>n;
int**a=new int*[n];
for(int i=0;i<n;i++)
a[i]=new int[n];
for(int i=0;i<n;i++)
{
for(int j=0;j<n;j++)
{
cin>>a[i][j];
}
}
int x=(n+1)/2;
solve(0,0,x);
for(int i=0;i<n;i++)
{
for(int j=0;j<n;j++)
{
sum+=a[i][j];
// cout<<a[i][j]<<" ";
}
}
cout<<sum<<endl;
return 0;
}