LeetCode——944. 删列造序

简介: LeetCode——944. 删列造序

944. 删列造序


题目描述

答案

我的答案

官网答案

直接遍历


题目描述


给你由 n 个小写字母字符串组成的数组 strs,其中每个字符串长度相等。


这些字符串可以每个一行,排成一个网格。例如,strs = ["abc", "bce", "cae"] 可以排列为:

abc

bce

cae

你需要找出并删除 不是按字典序升序排列的 列。在上面的例子(下标从 0 开始)中,列 0('a', 'b', 'c')和列 2('c', 'e', 'e')都是按升序排列的,而列 1('b', 'c', 'a')不是,所以要删除列 1 。

返回你需要删除的列数。


示例 1:

输入:strs = [“cba”,“daf”,“ghi”]

输出:1

解释:网格示意如下:

cba

daf

ghi

列 0 和列 2 按升序排列,但列 1 不是,所以只需要删除列 1 。


示例 2:

输入:strs = [“a”,“b”]

输出:0

解释:网格示意如下:

a

b

只有列 0 这一列,且已经按升序排列,所以不用删除任何列。


示例 3:

输入:strs = [“zyx”,“wvu”,“tsr”]

输出:3

解释:网格示意如下:

zyx

wvu

tsr

所有 3列都是非升序排列的,所以都要删除。


提示:

n == strs.length

1 <= n <= 100

1 <= strs[i].length <= 1000

strs[i] 由小写英文字母组成


答案


我的答案


class Solution {
    public int minDeletionSize(String[] strs) {
        int y = 0;
        for (int i = 0; i < strs[0].length(); i++) {
            int x = 0;
            for (String str : strs) {
                if (x <= str.charAt(i)) {
                    x = str.charAt(i);
                } else {
                    y++;
                    break;
                }
            }
        }
        return y;
    }
}


官网答案


直接遍历


思路与算法


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


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


代码

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;
    }
}


复杂度分析


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

空间复杂度:O(1)。

相关文章
|
6月前
leetcode-472. 连接词
leetcode-472. 连接词
49 0
|
3月前
|
算法
LeetCode第66题加一
LeetCode第66题"加一"的解题方法,通过遍历数组从后向前处理每一位的加法,并考虑进位情况,最终实现给定数字加一的功能。
LeetCode第66题加一
|
6月前
|
消息中间件 Kubernetes NoSQL
LeetCode 3、28、1351
LeetCode 3、28、1351
|
存储
leetcode:53.最大字序和
给定一个整数数组 nums ,找到一个具有最大和的连续子数组(子数组最少包含一个元素),返回其最大和。
53 0
|
索引
|
存储 Python
LeetCode 66. Plus One
给定表示非负整数的非空数字数组,加上整数的1。 存储数字使得最高有效数字位于列表的开头,并且数组中的每个元素包含单个数字。 您可以假设整数不包含任何前导零,除了数字0本身。
92 0
LeetCode 66. Plus One
LeetCode 354. Russian Doll Envelopes
给定一些标记了宽度和高度的信封,宽度和高度以整数对形式 (w, h) 出现。当另一个信封的宽度和高度都比这个信封大的时候,这个信封就可以放进另一个信封里,如同俄罗斯套娃一样。 请计算最多能有多少个信封能组成一组“俄罗斯套娃”信封(即可以把一个信封放到另一个信封里面)。
81 0
LeetCode 354. Russian Doll Envelopes
leetcode第54题
在 leetcode 的 solution 和 discuss 看了下,基本就是这个思路了,只是实现上有些不同,怎么用来标记是否走过,当前方向,怎么遍历,实现有些不同,但本质上是一样的。就是充分理解题意,然后模仿遍历的过程。
104 0
leetcode第54题
leetcode第46题
这是自己开始想到的一个方法,考虑的思路是,先考虑小问题怎么解决,然后再利用小问题去解决大问题。没错,就是递归的思路。比如说, 如果只有 1 个数字 [ 1 ],那么很简单,直接返回 [ [ 1 ] ] 就 OK 了。 如果加了 1 个数字 2, [ 1 2 ] 该怎么办呢?我们只需要在上边的情况里,在 1 的空隙,也就是左边右边插入 2 就够了。变成 [ [ 2 1 ], [ 1 2 ] ]。
leetcode第46题