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;
    }

  • 相关阅读:
    isNUll ,对于sql中的一个表的description的NULL和空格的处理
    Thread类学习
    java学习计划
    HTTP请求过程(http是一种无状态协议,即不建立持久的连接)
    JS事件流(W3C与IE区别)
    学习Javascript闭包
    div内长串数字或字母不断行处理
    仿购物车加减数字
    多行文字两行断尾点点点显示
    MegaCli命令详解
  • 原文地址:https://www.cnblogs.com/xufeng123/p/12757681.html
Copyright © 2011-2022 走看看