zoukankan      html  css  js  c++  java
  • c++检测矩阵

    题目描述

      给定n*n由0和1组成的矩阵,如果矩阵的每一行和每一列的1的数量都是偶数,则认为符合条件。
      你的任务就是检测矩阵是否符合条件,或者在仅改变一个矩阵元素的情况下能否符合条件。
      "改变矩阵元素"的操作定义为0变成1或者1变成0。

    输入

      输入n + 1行,第1行为矩阵的大小n(0 < n < 100),以下n行为矩阵的每一行的元素,元素之间以一个空格分开。

    输出

      如果矩阵符合条件,则输出OK;
      如果矩阵仅改变一个矩阵元素就能符合条件,则输出需要改变的元素所在的行号和列号,以一个空格分开。
      如果不符合以上两条,输出Corrupt。

    样例输入

    4
    1 0 1 0
    0 0 0 0
    1 1 1 1
    0 1 0 1
    样例输出

    OK

    #include <bits/stdc++.h>

    using namespace std;
    int num[100][100],hang[100],lie[100],n,i,j,s,counth,countl;

    int main()
    {
    scanf("%d",&n);
    for(i=0;i<n;i++)
    for(j=0;j<n;j++)
    scanf("%d",&(num[i][j]));
    for(i=0;i<n;i++)
    {
    s=0;
    for(j=0;j<n;j++)
    s+=num[i][j];
    hang[i]=s%2;
    }
    for(j=0;j<n;j++)
    {
    s=0;
    for(i=0;i<n;i++)
    s+=num[i][j];
    lie[j]=s%2;
    }
    counth=countl=0;
    for(i=0;i<n;i++)
    if(hang[i]) counth++;
    for(j=0;j<n;j++)
    if(lie[j]) countl++;
    if(counth==countl)
    {
    if(counth==0)
    printf("OK");
    else if(counth==1)
    {
    for(i=0;i<n;i++)
    if(hang[i]) break;
    for(j=0;j<n;j++)
    if(lie[j]) break;
    printf("%d %d",i+1,j+1);
    }
    else printf("Corrupt");
    }
    else printf("Corrupt");
    return 0;
    }

  • 相关阅读:
    UVA 10827 Maximum sum on a torus 最大矩阵和
    UVA 11100 The Trip, 2007 水题一枚
    编程之美2015测试赛 题目1 : 同构
    UVA 10801 Lift Hopping Floyd
    UVA 11389 The Bus Driver Problem 贪心水题
    UVA 11039 Building designing 贪心
    UVA 11636 Hello World! 水题
    poj 3070 Fibonacci 矩阵快速幂
    hdu 1757 A Simple Math Problem 矩阵快速幂
    了解常见的 Azure 灾难
  • 原文地址:https://www.cnblogs.com/xufeng123/p/12757681.html
Copyright © 2011-2022 走看看