zoukankan      html  css  js  c++  java
  • 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;
    }

  • 相关阅读:
    Dynamic Language Runtime 微软打出的王牌
    微软发布IronRuby
    点亮Web的灯silverlight
    Miguel de Icaza 细说 Mix 07大会上的Silverlight和DLR
    奚江华的几篇Silverlight文章
    Microsoft 的 OpenSource Licence
    CPython 和IronPython的基准测试
    Mobile上的Silverlight
    Switcher Vista Areo 工具
    ASP.NET AJAX 控件开发基础
  • 原文地址:https://www.cnblogs.com/icode-girl/p/4660894.html
Copyright © 2011-2022 走看看