经典算法题之删列造序(二)

解决方案

方法一:直接遍历思路和算法

题目要求删除不是按字典序升序排列的列,由于每个字符串的长度都相等,我们可以逐列访问字符串数组,统计不是按字典序升序排列的列。

对于第 j 列的字符串,我们需要检测所有相邻字符是否均满足 strs i−1 j ≤ strs i j

代码

Java

复制代码
class Solution {
    public int minDeletionSize(String[] strs) {
        int row = strs.length;
        int col = strs[0].length();
        int ans = 0;
        for (int j = 0; j < col; ++j) {
            for (int i = 1; i < row; ++i) {
                if (strs[i - 1].charAt(j) > strs[i].charAt(j)) {
                    ans++;
                    break;
                }
            }
        }
        return ans;
    }
}

C++

复制代码
class Solution {
public:
    int minDeletionSize(vector<string>& strs) {
        int row = strs.size();
        int col = strs[0].size();
        int ans = 0;
        for (int j = 0; j < col; ++j) {
            for (int i = 1; i < row; ++i) {
                if (strs[i - 1][j] > strs[i][j]) {
                    ans++;
                    break;
                }
            }
        }
        return ans;
    }
};

C

复制代码
int minDeletionSize(char ** strs, int strsSize) {
    int row = strsSize;
    int col = strlen(strs[0]);
    int ans = 0;
    for (int j = 0; j < col; ++j) {
        for (int i = 1; i < row; ++i) {
            if (strs[i - 1][j] > strs[i][j]) {
                ans++;
                break;
            }
        }
    }
    return ans;
}

复杂度分析

时间复杂度:O(m×n),其中 m 为字符串数组的长度,n 为数组中每个字符串的长度,判定每一列的的字典序需要遍历字符串数组每一列,因此时间复杂度为 O(m×n)。

空间复杂度:O(1)。

相关推荐
孬甭_13 小时前
栈和队列
c语言·数据结构
骄马之死13 小时前
ThreadLocal 核心原理
java·jvm·算法
weixin_4684668513 小时前
最短路径与最小生成树算法区分实战指南
网络·算法·最小生成树·prim·并查集·最短路径·dijk
CQU_JIAKE13 小时前
5.28【A】
算法
Stzzfntty13 小时前
嵌软c八股刷题记录
c语言·开发语言·算法
墨白曦煜13 小时前
算法实战笔记:数组操作的底层逻辑与五大解题范式(一)
笔记·算法
枕星而眠13 小时前
数据结构八大排序详解(二):四大高阶排序(归并/快排/堆/基数)
数据结构
t-think13 小时前
冒泡排序和qsort模拟实现
c语言·算法
LuminousCPP13 小时前
C 语言通讯录补坑篇:终版遗留 Bug 修复,解决修改姓名输入错乱问题
c语言·开发语言·数据结构·经验分享·笔记·顺序表