原题链接: https://codeforces.com/contest/1426/problem/B

测试样例
input
 6
 3 4
 1 2
 5 6
 5 7
 7 4
 8 9
 9 8
 2 5
 1 1
 1 1
 2 2
 2 2
 1 100
 10 10
 10 10
 1 2
 4 5
 8 4
 2 2
 1 1
 1 1
 1 2
 3 4
 1 2
 1 1
 1 1
 output
 YES
 NO
 YES
 NO
 YES
 YES
Note
The first test case of the input has three types of tiles, they are shown on the picture below.
 Masha can construct, for example, the following square of size 4×4 which is a symmetric matrix:
题意: 给你个类型的
的正方形格,你需要去构建一个
的对称矩阵,问你是否可行。
解题思路: 我们要抓住题中的关键信息:基础格为的,所以我们不可能构建一个
为奇数的对称矩阵。这里即可特判。 那么还有哪些信息呢?就是正方形格不能被旋转放置以及正方形格的数量不限,可以任意使用。OK,我们来看这个样例。我们发现,控制这个对称的只有单元格的右上和左下。因为如果我们使用同一个单元格的话,左上和右下是与别的单元格相同的,不关乎内部构造(仔细理解这段话,仔细看一下样例。)。 故,此题易解。
AC代码
/*
*
*/
//POJ不支持
//i为循环变量,a为初始值,n为界限值,递增
//i为循环变量, a为初始值,n为界限值,递减。
using namespace std;
const int inf = 0x3f3f3f3f;//无穷大
const int maxn = 1e5;//最大值。
typedef long long ll;
typedef long double ld;
typedef pair<ll, ll>  pll;
typedef pair<int, int> pii;
//*******************************分割线,以上为自定义代码模板***************************************//
int t,n,m;
int main(){
  //freopen("in.txt", "r", stdin);//提交的时候要注释掉
  IOS;
  while(cin>>t){
    while(t--){
      cin>>n>>m;
      //我只要有右上等于左下就好。
      int a,b,c,d;
      bool flag=false;
      rep(i,0,n-1){
        cin>>a>>b>>c>>d;
        if(b==c){
          flag=true;
        }
      }
      if(m%2){
        cout<<"NO"<<endl;
        continue;
      }
      if(flag){
        cout<<"YES"<<endl;
      }
      else{
        cout<<"NO"<<endl;
      }
    }
  }
  return 0;
}                
                










