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)。

相关文章
|
7月前
LeetCode
LeetCode
44 0
|
7月前
|
算法
leetcode:389. 找不同
leetcode:389. 找不同
32 0
|
7月前
leetcode-827:最大人工岛
leetcode-827:最大人工岛
70 0
|
存储 Python
LeetCode 66. Plus One
给定表示非负整数的非空数字数组,加上整数的1。 存储数字使得最高有效数字位于列表的开头,并且数组中的每个元素包含单个数字。 您可以假设整数不包含任何前导零,除了数字0本身。
94 0
LeetCode 66. Plus One
leetcode 283 移动零
leetcode 283 移动零
61 0
|
存储
leetcode第52题
可以发现对于同一条副对角线,row + col 的值是相等的。 对于同一条主对角线,row - col 的值是相等的。 我们同样可以用一个 bool 型数组,来保存当前对角线是否有元素,把它们相加相减的值作为下标。 对于 row - col ,由于出现了负数,所以可以加 1 个 n,由 [ - 3, 3 ] 转换为 [ 1 , 7 ] 。
leetcode第52题
leetcode第34题
从左向右遍历,一旦出现等于 target 的值就结束,保存当前下标。如果从左到右没有找到 target,那么就直接返回 [ -1 , -1 ] 就可以了,因为从左到右没找到,那么从右到左也一定不会找到的。如果找到了,然后再从右到左遍历,一旦出现等于 target 的值就结束,保存当前下标。 时间复杂度是 O(n)并不满足题意,但可以了解下这个思路,从左到右,从右到左之前也遇到过。
leetcode第34题
leetcode第51题
较经典的回溯问题了,我们需要做的就是先在第一行放一个皇后,然后进入回溯,放下一行皇后的位置,一直走下去,如果已经放的皇后的数目等于 n 了,就加到最后的结果中。然后再回到上一行,变化皇后的位置,然后去找其他的解。 期间如果遇到当前行所有的位置都不能放皇后了,就再回到上一行,然后变化皇后的位置。再返回到下一行。 说起来可能还费力些,直接看代码吧。
leetcode第51题
|
算法
leetcode第30题
如上图,利用循环变量 i ,依次后移,判断每个子串是否符合即可。 怎么判断子串是否符合?这也是这个题的难点了,由于子串包含的单词顺序并不需要固定,如果是两个单词 A,B,我们只需要判断子串是否是 AB 或者 BA 即可。如果是三个单词 A,B,C 也还好,只需要判断子串是否是 ABC,或者 ACB,BAC,BCA,CAB,CBA 就可以了,但如果更多单词呢?那就崩溃了。 链接)的作者提出了,用两个 HashMap 来解决。首先,我们把所有的单词存到 HashMap 里,key 直接存单词,value 存单词出现的个数(因为给出的单词可能会有重复的,所以可能是 1 或 2 或者其他)。然后扫描子
125 0
leetcode第30题