• E. Matrix and Shifts(思维+遍历正对角线)


    Problem - 1660E - Codeforces

    你会得到一个大小为n×n的二进制矩阵A。行从上到下从1到n编号,列从左到右从1到n编号,位于第i行和第j列交点的元素称为Aij。考虑一组4个操作。

    循环地将所有行向上移动。索引为i的行将被写在i-1行的位置上(2≤i≤n),索引为1的行将被写在n行的位置上。
    循环地将所有的行向下移动。索引i的行将被写在i+1行的位置(1≤i≤n-1),索引n的行将被写在1行的位置。
    循环地将所有列向左移动。索引为j的列将被写在j-1列的位置上(2≤j≤n),索引为1的列将被写在n列的位置上。
    循环地将所有的列向右移动。索引j的列将被写在j+1列的位置上(1≤j≤n-1),索引n的列将被写在1列的位置上。
    3×3矩阵在左边显示的是进行3次运算之前,右边显示的是进行3次运算之后。
    你可以对矩阵进行任意数量(可能是零)的操作;这些操作可以按任何顺序进行。

    之后,你可以执行任意数量(可能为零)的新的xor-操作。

    选择任何元素Aij并赋予其新的值Aij⊕1。换句话说,(Aij+1)mod2的值将被写入元素Aij中。
    每次应用这个xor操作都要花费一个burl。请注意,4个移位操作--是免费的。这4个操作只能在进行xor-操作之前进行。

    输出为使A矩阵单一化所需的最小布尔数。单一矩阵是指主对角线上有1,其余元素为0的矩阵(也就是说,如果i=j,Aij=1,否则Aij=0)。

    输入
    输入的第一行包含一个整数t(1≤t≤104)--测试中测试案例的数量。

    接下来是测试用例的描述。在每个测试用例之前,在输入中写一个空行。

    每个测试用例的第一行包含一个数字n (1≤n≤2000)

    接下来是n行,每行正好包含n个字符,并且只由0和1组成。这些行描述了矩阵中各元素的值。

    保证所有测试案例的n2值之和不超过4⋅106。

    输出
    对于每个测试用例,输出为使A矩阵单元化所需的最小布尔数。换句话说,在对矩阵进行循环移位后,打印出使A矩阵成为单数所需的最小xor操作数。

    例子
    输入复制
    4

    3
    010
    011
    100

    5
    00010
    00001
    10000
    01000
    00100

    2
    10
    10

    4
    1111
    1011
    1111
    1111
    outputCopy
    1
    0
    2
    11
    注意
    在第一个测试案例中,你可以这样做:首先,将所有的行循环下移,然后矩阵的主对角线将只包含 "1"。然后有必要对唯一不在主对角线上的 "1 "进行xor操作。

    在第二个测试案例中,你可以通过对矩阵应用操作2--行的循环上移两次来制造一个单元矩阵。

    题解:

    根据四种变化我们发现,他是整体变化的,

    无论如何变化,所有正对角上的点是不变的

     黄色的也是我所说的正对角线(类似黄色与黑色的都是)

    所以我们遍历这些对角线即可,找到1最多的

    1. #include<iostream>
    2. #include<algorithm>
    3. #include<cstring>
    4. #include<string>
    5. #include<map>
    6. #include<vector>
    7. #include<queue>
    8. using namespace std;
    9. #define int long long
    10. //1 1 3 3 3
    11. char a[2005][2005];
    12. void solve()
    13. {
    14. int n;
    15. cin >> n;
    16. int s = 0;
    17. for(int i = 0;i < n;i++)
    18. {
    19. for(int j = 0;j < n;j++)
    20. {
    21. cin >> a[i][j];
    22. if(a[i][j] == '1')
    23. {
    24. s++;
    25. }
    26. }
    27. }
    28. int ans = 0;
    29. for(int i = 0;i < n;i++)
    30. {
    31. int k = 0,tmp = 0;
    32. for(int j = i;k < n;k++,j = (j+1)%n)
    33. {
    34. if(a[k][j] == '1')
    35. {
    36. tmp++;
    37. }
    38. }
    39. ans = max(tmp,ans);
    40. }
    41. cout<<n - ans + s - ans<<"\n";
    42. }
    43. signed main()
    44. {
    45. // ios::sync_with_stdio(false);
    46. // cin.tie(0);
    47. // cout.tie(0);
    48. int t = 1;
    49. cin >> t;
    50. while(t--)
    51. {
    52. solve();
    53. }
    54. }

     

  • 相关阅读:
    计算机丢失MSVCP140.dll的解决方法分享
    华为配置AP和AC之间NAT穿越示例
    【前端】伪元素的postion:absolute是对哪里的?
    JavaScript 条件判断语句以及示例和详细代码解释为什么这样写(1)
    现在报PMP还来得及参加9月的考试吗?分享敏捷全真模拟题
    Leetcode刷题108. 将有序数组转换为二叉搜索树
    字符集与编码
    盘点具备盈利潜力的几大加密板块,以及潜在的投资机会
    将VMProtect集成到应用程序教程之实模式(三):测试结果
    IDEA调试技巧总结
  • 原文地址:https://blog.csdn.net/m0_64158084/article/details/128078912