• POJ 2965贪心神解


    貌似和POj1753一样是一般都是用为位运算+枚举做的。但是捏。这里用了贪心算法很容易。怎么样才能做到只把当前位置的+改为-而不改变其它所有位置的符号呢。嗯。就是把当前位置所在的行和列所在的元素都反转一次。最后统计操作数是记数的位置就是要操作的位置。详见代码:

    #include<stdio.h>
    #include<string.h>
    #include<iostream>
    using namespace std;

    char m;
    int num[5][5];

    int main()
    {
        memset(num, 0, sizeof(num));
        for (int i=0; i<4; ++i)
        {
            for (int j=0; j<4; ++j)
            {
                cin >> m;
                if (m == '+')
                {
                    for (int k=0; k<4; ++k)
                    {
                       num[i][k]++;
                       num[k][j]++;
                    }
                    num[i][j]--;
                }
            }
        }
        int tot = 0;
        for (int i=0; i<4; ++i)
        {
            for (int j=0; j<4; ++j)
            {
                tot += num[i][j] % 2;
            }
        }
        cout << tot << endl;
        for (int i=0; i<4; ++i)
        {
            for (int j=0; j<4; ++j)
            {
                if (num[i][j] % 2)
                {
                    cout << i+1 << ' ' << j+1 << endl;
                }
            }
        }
        return 0;
    }

  • 相关阅读:
    sql 计算auc
    tf.app.flags
    transformer
    python 直连 hive
    rnn 详解
    yolov3
    记学习react-native
    html5横、竖屏状态 以及禁止横屏
    图片懒加载
    npm安装的时候报-4048
  • 原文地址:https://www.cnblogs.com/icode-girl/p/4660894.html
Copyright © 2020-2023  润新知