每天一道 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;
}
相关文章
|
8月前
|
算法 JavaScript 前端开发
递归的递归之书:第五章到第九章
递归的递归之书:第五章到第九章
163 0
|
8月前
|
人工智能 自然语言处理 算法
思维链不存在了?纽约大学最新研究:推理步骤可省略
【5月更文挑战第26天】纽约大学研究发现,Transformer模型在处理复杂任务时可能不依赖思维链,而是通过填充符号实现计算。实验显示,填充符号能提升模型在特定任务中的准确率,扩展其表达能力,尤其是在处理嵌套量词问题时。然而,模型有效利用填充符号的学习是个挑战,因填充符号的隐藏层表示不易判断。研究提示,Transformer模型可能通过填充符号并行化解决TC0类问题,但可能使决策过程变得不透明,影响可解释性。该研究为优化语言模型提供了新思路,但也提出了可解释性与计算效率之间平衡的议题。[链接](https://arxiv.org/pdf/2404.15758)
72 1
|
7月前
|
算法 Java 程序员
Java多态:不只是代码,更是思想的碰撞!
【6月更文挑战第17天】Java的多态性展示了编程的哲学,通过抽象基类(如`AudioFile`、`Shape`、`Product`)和重写方法实现。案例中,音乐播放器利用多态统一处理不同音频格式,绘图软件优雅地绘制各种形状,电商系统灵活管理商品信息。多态简化代码,增强可扩展性,连接技术与设计,体现代码的灵活性和艺术性。
47 0
C生万物 | 从浅入深理解指针【第四部分】(qsort的使用和模拟实现)
C生万物 | 从浅入深理解指针【第四部分】(qsort的使用和模拟实现)
|
C语言
C语言程序设计(王立柱)第五章答案 结构,联合,枚举
只有聪明人才能看见的摘要~( ̄▽ ̄~)~
96 0
|
算法 搜索推荐
《十大排序算法》让你的思维流动起来。今天的主角又是排序思想你了解多少。每种算法的内容在代码中体现出来。
《十大排序算法》让你的思维流动起来。今天的主角又是排序思想你了解多少。每种算法的内容在代码中体现出来。
201 0
《十大排序算法》让你的思维流动起来。今天的主角又是排序思想你了解多少。每种算法的内容在代码中体现出来。
|
人工智能
每天两道 CodeForces 构造/思维题 (day5)
每天两道 CodeForces 构造/思维题 (day5)
每天两道 CodeForces 构造/思维题 (day5)
codeforces1013——D. Chemical table(思维+转化+并查集)
codeforces1013——D. Chemical table(思维+转化+并查集)
88 0