每天一道 CodeForces 构造/思维题 (day2)

简介: 每天一道 CodeForces 构造/思维题 (day2)

@TOC

1题目

题目链接 C.Column Swapping

题目大意:给你一个二维矩阵,问是否能够交换两列,使得每一行都是非递减的

2思路

条件:

  1. 只能交换两列
  2. 每一行非递减

我们可以枚举每一行,将每一行从到大排个序,然后与原来的行比对,如果在同一位置上元素不同,那么这一元素一定是要被交换的,我们记录下所有在需要交换的元素个数cnt

  1. cnt == 0,表示没有元素被交换,继续找下一行
  2. cnt == 2,表示有两个元素需要交换,记录下这两个位置lr。以便后续处理
  3. cnt > 2,表示有三个以上元素被交换了,那么不满足条件1

cnt==2时,我们已经知道需要某一行需要交换两个位置了,但不代表其他行交换这两位置之后也满足条件,我们需要将其他行的这两列交换后,看满不满足此行满足条件2,枚举每一行即可,如果最后都满足,那么就输出lr

3代码

#include <bits/stdc++.h>
using namespace std;
int n, m;
void solve()
{
    cin >> n >> m;
    vector<vector<int>> g(n, vector<int>(m));
    for (int i = 0; i < n; i++)
    {
        for (int j = 0; j < m; j++)
            scanf("%d", &g[i][j]);
    }
    vector<int> v;
    int l = -1, r = 0;
    int cnt = 0;
    for (int i = 0; i < n; i++)
    {
        v = g[i];
        sort(v.begin(), v.end());
        for (int j = 0; j < m; j++)
        {
            if (v[j] != g[i][j])
            {
                if (l == -1)
                    l = j;
                else
                    r = j;
                cnt++;
            }
        }
        if (cnt)
            break;
    }
    if (cnt > 2)
    {
        cout << "-1\n";
        return;
    }
    if (cnt == 0)
    {
        cout << "1 1\n";
        return;
    }
    for (int i = 0; i < n; i++)
    {
        v = g[i];
        int cnt = 0;
        swap(g[i][l], g[i][r]);
        for (int j = 1; j < m; j++)
        {
            if (g[i][j] < g[i][j - 1])
            {
                cout << "-1\n";
                return;
            }
        }
    }
    cout << l + 1 << " " << r + 1 << endl;
    return;
}
signed main()
{
    // freopen("in.in", "r", stdin);
    // freopen("out.out", "w", stdout);
    int t;
    cin >> t;
    while (t--)
    {
        solve();
    }

    return 0;
}
相关文章
|
1月前
|
算法 Java C语言
第十四届蓝桥杯集训——练习解题阶段(无序阶段)-ALGO-468 三角形高
第十四届蓝桥杯集训——练习解题阶段(无序阶段)-ALGO-468 三角形高
29 0
|
1月前
|
Java C语言 C++
第十四届蓝桥杯集训——练习解题阶段(无序阶段)-ALGO-91 Anagrams问题
第十四届蓝桥杯集训——练习解题阶段(无序阶段)-ALGO-91 Anagrams问题
24 0
|
1月前
|
Java C语言 C++
第十四届蓝桥杯集训——练习解题阶段(无序阶段)-ALGO-116 最大的算式
第十四届蓝桥杯集训——练习解题阶段(无序阶段)-ALGO-116 最大的算式
36 0
|
20天前
|
存储 人工智能 决策智能
每日一题——博弈论(枚举与暴力)
每日一题——博弈论(枚举与暴力)
12 1
每日一题——博弈论(枚举与暴力)
|
1月前
|
Java C++ Python
第十四届蓝桥杯集训——练习解题阶段(无序阶段)-ALGO-161 Abbott’s Revenge(C++写法)
第十四届蓝桥杯集训——练习解题阶段(无序阶段)-ALGO-161 Abbott’s Revenge(C++写法)
129 42
|
1月前
|
Java C语言 C++
第十四届蓝桥杯集训——练习解题阶段(无序阶段)-ALGO-446 递归输出数字
第十四届蓝桥杯集训——练习解题阶段(无序阶段)-ALGO-446 递归输出数字
46 1
|
1月前
|
Java C语言 C++
第十四届蓝桥杯集训——练习解题阶段(无序阶段)-ALGO-645 加法分解
第十四届蓝桥杯集训——练习解题阶段(无序阶段)-ALGO-645 加法分解
27 0
|
1月前
|
算法 Java C语言
第十四届蓝桥杯集训——练习解题阶段(无序阶段)-ALGO-913 二元函数
第十四届蓝桥杯集训——练习解题阶段(无序阶段)-ALGO-913 二元函数
25 0
|
1月前
|
算法 Java C语言
第十四届蓝桥杯集训——练习解题阶段(无序阶段)-ALGO-633 加法分解
第十四届蓝桥杯集训——练习解题阶段(无序阶段)-ALGO-633 加法分解
28 0
|
1月前
|
Java C语言 C++
第十四届蓝桥杯集训——练习解题阶段(无序阶段)-ALGO-84 大小写转换
第十四届蓝桥杯集训——练习解题阶段(无序阶段)-ALGO-84 大小写转换
32 0