711B - Chris and Magic Square 模拟
题目大意:在num[i][j]==0处填一个数使每行,每列,对角线的和相同,若果有多种答案输出一种。
题目思路:模拟
#include<iostream>
#include<algorithm>
#include<cstring>
#include<vector>
#include<stdio.h>
#include<stdlib.h>
#include<queue>
#include<math.h>
#include<map>
#define INF 0xffffffff
#define MAX 505
#define Temp 1000000000
#define MOD 1000000007
#define LL long long
#define PI acos(-1) using namespace std; long long num[MAX][MAX]; long long change(int n,int x,int y)
{
long long k=,sum1=,sum2=,sum3=,sum4=,sum=;
int op1=,op2=;
for(int i=; i<=n; i++)
{
if(i!=x)
{
for(int j=; j<=n; j++)
k+=num[i][j];
break;
}
}
for(int i=; i<=n; i++)
{
sum=;
if(i==x)
{
for(int j=; j<=n; j++)
sum1+=num[i][j];
continue;
}
for(int j=; j<=n; j++)
{
sum+=num[i][j];
}
if(sum!=k)
return -;
} for(int i=; i<=n; i++)
{
sum=;
if(i==y)
{
for(int j=; j<=n; j++)
sum2+=num[j][i];
continue;
}
for(int j=; j<=n; j++)
{
sum+=num[j][i];
}
if(sum!=k)
return -;
}
if(x==y && x==(n+)/ && n%!=)
{
for(int i=; i<=n; i++)
{
sum3+=num[i][i];
sum4+=num[i][n-i+];
}
long long a=k-sum1;
long long b=k-sum2;
long long c=k-sum3;
long long d=k-sum4;
if(a!=b || a!=c || a!=d || b!=c || b!=d || c!=d)
return -;
else if(a<)
return -;
return a;
}
for(int i=; i<=n; i++)
{
if(num[i][i]==)
{
op1=;
}
sum3+=num[i][i];
if(num[i][n+-i]==)
{
op2=;
}
sum4+=num[i][n+-i];
}
if(op1== && sum3!=k)
return -;
if(op2== && sum4!=k)
return -;
if(op1)
{
long long c=k-sum3;
long long a=k-sum1;
long long b=k-sum2;
if(a!=b || a!=c || b!=c)
return -;
else if(a < )
return -;
return a;
}
if(op2)
{
long long c=k-sum4;
long long a=k-sum1;
long long b=k-sum2;
if(a!=b || a!=c || b!=c)
return -;
else if(a < )
return -;
return a;
}
long long a=k-sum1;
long long b=k-sum2;
if(a!=b || (a==b && a<))
return -;
return a;
} int main()
{
int n,x,y;
while(scanf("%d",&n)!=EOF)
{
memset(num,,sizeof(num));
for(int i=; i<=n; i++)
{
for(int j=; j<=n; j++)
{
scanf("%lld",&num[i][j]);
if(num[i][j]==)
{
x=i;
y=j;
}
}
}
if(n==)
{
printf("2\n");
continue;
}
long long ok=change(n,x,y);
printf("%lld\n",ok);
}
return ;
}
711B - Chris and Magic Square 模拟的更多相关文章
- 【模拟】Codeforces 711B Chris and Magic Square
题目链接: http://codeforces.com/problemset/problem/711/B 题目大意: N*N的矩阵,有且只有一个0,求要把这个矩阵变成幻方要填什么正数.无解输出-1.幻 ...
- codeforces 711B - Chris and Magic Square(矩阵0位置填数)
题目链接:http://codeforces.com/problemset/problem/711/B 题目大意: 输入 n ,输入 n*n 的矩阵,有一个占位 0 , 求得将 0 位置换成其他的整数 ...
- CodeForces 711B Chris and Magic Square (暴力,水题)
题意:给定n*n个矩阵,其中只有一个格子是0,让你填上一个数,使得所有的行列的对角线的和都相等. 析:首先n为1,就随便填,然后就是除了0这一行或者这一列,那么一定有其他的行列是完整的,所以,先把其他 ...
- CodeForces 711B Chris and Magic Square
简单题. 找一个不存在$0$的行,计算这行的和(记为$sum$),然后就可以知道$0$那个位置应该填的数字(记为$x$). 如果$x<=0$,那么无解,否则再去判断每一行,每一列以及两个斜对角的 ...
- CF 711B - Chris and Magic Square
挺简单的一道题,但是做的时候没想好就开始写代码了,导致迷之WA,还是要多练习啊. #include <iostream> #include <cstdio> #include ...
- codeforces 711B B. Chris and Magic Square(水题)
题目链接: B. Chris and Magic Square 题意: 问在那个空位子填哪个数可以使行列对角线的和相等,就先找一行或者一列算出那个数,再验证是否可行就好; AC代码: #include ...
- Codeforces Round #369 (Div. 2) B. Chris and Magic Square 水题
B. Chris and Magic Square 题目连接: http://www.codeforces.com/contest/711/problem/B Description ZS the C ...
- Codeforces Round #369 (Div. 2) B. Chris and Magic Square (暴力)
Chris and Magic Square 题目链接: http://codeforces.com/contest/711/problem/B Description ZS the Coder an ...
- Chris and Magic Square CodeForces - 711B
ZS the Coder and Chris the Baboon arrived at the entrance of Udayland. There is a n × n magic grid o ...
随机推荐
- [SOJ] can I post the letter?
1155. Can I Post the letter Constraints Time Limit: 1 secs, Memory Limit: 32 MB Description I am a t ...
- NOIP2015-普及组复赛-第一题-金币
题目描述 Description 国王将金币作为工资,发放给忠诚的骑士.第一天,骑士收到一枚金币:之后两天(第二天和第三天),每天收到两枚金币:之后三天(第四.五.六天),每天收到三枚金币:之后四天( ...
- Buffett saying
1. 人生财富就像滚雪球,最重要的是发现很湿的雪和很长的坡. 2. 雪球想滚大,必须要有最坚实的核心:一生坚持的价值投资理念 价值投资一直是巴菲特投资理念的核心,他始终认为投资企业最重要的是要看准企业 ...
- cmd 进入mysql
从cmd中进入MySQL的命令界面 1.开始中找出运行:输入cmd2.查找appserv所在盘,我的在D盘,所以接着输入:d:3.在d盘中查找mysql所在目录:cd appserv\mysql\bi ...
- .NET 简单的扩展方法使用。
写代码时,我们经常会碰到dll中提供的方法,不够用或者不好用的情况.而且我们也不方便去更改dll本身的源码. 这时候我们可以使用.NET提供的"扩展方法"去解决这个问题. 下面我写 ...
- jarring type lambda
object IntStateMonad extendsMonad[({type IntState[A] = State[Int, A]})#IntState] {...}This syntax ca ...
- 一个初学者的辛酸路程-socket编程-8
前言: 你会发现会网络是多么幸福的事情 主要内容: socket 概念: socket本质上就是2台网络互通的电脑之间,架设一个通道,两台电脑通过这个通道来实现数据的互相传递.我们知道网络通信都是基于 ...
- css实现遮罩层,父div透明,子div不透明
使用元素的opacity 属性,设置遮罩层的效果, 主要 样式是:background-color: #ooo; opacity:0.3; <div style="width:500p ...
- hibernate异常:org.hibernate.exception.GenericJDBCException
异常:org.hibernate.exception.GenericJDBCException 提示:Cannot open connection 提示:不能打开链接 一般这个异常是由 java.sq ...
- scala集合和高级函数操作
scala常用函数操作 reduceLeft 是将集合的元素从左向右进行所需要的相应操作,图以减法为例展示,表达的算法是 : 1-2-3-4-5 例: (1 to 5).reduceLeft(_ ...