522. 最长特殊序列 II

题目

给定字符串列表 strs ,返回其中最长的特殊序列的长度。如果最长特殊序列不存在,返回 -1。

特殊序列定义如下:该序列为某字符串独有的子序列(即不能是其他字符串的子序列)。

字符串 s 的子序列可以通过删去字符串 s 中的某些字符实现。

例如,“abc” 是 “aebdc” 的子序列,因为您可以删除"aebdc"中的下划线字符来得到 “abc” 。“aebdc"的子序列还包括"aebdc”、 “aeb” 和 “” (空字符串)。

示例 1:

  • 输入: strs = ["aba","cdc","eae"]
  • 输出: 3

示例 2:

  • 输入: strs = ["aaa","aaa","aa"]
  • 输出: -1

提示:

  • 2 <= strs.length <= 50
  • 1 <= strs[i].length <= 10
  • strs[i] 只包含小写英文字母

代码

完整代码

#include <string.h>
#include <stdio.h>
#include <stdlib.h>
#include <stdbool.h>

typedef struct {
    char* s;
    int len;
} combo_t;

int cmp(const void *a, const void *b) {
    combo_t* pofa = (combo_t*)a;
    combo_t* pofb = (combo_t*)b;
    return pofb->len - pofa->len;
}

bool isSubsequence(char* a, char* b) {
    // 判断 a 是否为 b 的子序列
    int i = 0, j = 0;
    while (i < strlen(a) && j < strlen(b)) {
        if (a[i] == b[j]) {
            i++;
        }
        j++;
    }
    return i == strlen(a);
}

int findLUSlength(char** strs, int strsSize) {
    combo_t* arr = (combo_t*)calloc(strsSize, sizeof(combo_t));
    for (int i = 0; i < strsSize; i++) {
        arr[i].len = strlen(strs[i]);
        arr[i].s = strs[i];
    }
    qsort(arr, strsSize, sizeof(combo_t), cmp);

    for (int i = 0; i < strsSize; i++) {
        bool isUnique = true;

        // 检查是否是唯一的
        for (int j = 0; j < strsSize; j++) {
            if (i != j && arr[i].len == arr[j].len && strcmp(arr[i].s, arr[j].s) == 0) {
                isUnique = false;
                break;
            }
        }

        // 如果是唯一的,检查是否不是其他更长字符串的子序列
        if (isUnique) {
            bool isSub = false;
            for (int j = 0; j < i; j++) {
                if (isSubsequence(arr[i].s, arr[j].s)) {
                    isSub = true;
                    break;
                }
            }
            if (!isSub) {
                int len = arr[i].len;
                free(arr);
                return len;
            }
        }
    }

    free(arr);
    return -1;
}

思路分析

该问题可以通过以下步骤解决:

  1. 定义结构体:用来存储字符串和它们的长度。
  2. 排序:按照字符串的长度从大到小排序,这样可以先检查较长的字符串。
  3. 检查唯一性:检查当前字符串是否在列表中唯一。
  4. 判断子序列:如果当前字符串是唯一的,检查它是否不是其他更长字符串的子序列。
  5. 返回结果:如果满足条件,返回当前字符串的长度;否则返回 -1。

拆解分析

  1. 定义结构体和比较函数

    typedef struct {
        char* s;
        int len;
    } combo_t;
    
    int cmp(const void *a, const void *b) {
        combo_t* pofa = (combo_t*)a;
        combo_t* pofb = (combo_t*)b;
        return pofb->len - pofa->len;
    }
    

    结构体 combo_t 用于存储字符串及其长度。比较函数 cmp 用于按字符串长度从大到小排序。

  2. 检查是否为子序列

    bool isSubsequence(char* a, char* b) {
        int i = 0, j = 0;
        while (i < strlen(a) && j < strlen(b)) {
            if (a[i] == b[j]) {
                i++;
            }
            j++;
        }
        return i == strlen(a);
    }
    

    函数 isSubsequence 用于检查字符串 a 是否是字符串 b 的子序列。

  3. 主函数实现

    int findLUSlength(char** strs, int strsSize) {
        combo_t* arr = (combo_t*)calloc(strsSize, sizeof(combo_t));
        for (int i = 0; i < strsSize; i++) {
            arr[i].len = strlen(strs[i]);
            arr[i].s = strs[i];
        }
        qsort(arr, strsSize, sizeof(combo_t), cmp);
    
        for (int i = 0; i < strsSize; i++) {
            bool isUnique = true;
    
            for (int j = 0; j < strsSize; j++) {
            	// 这里可以优化,如果len 不同,就break,因为前面经过排序,len不同则strcmp一定 != 0
            	// 但是为了美观就不写了,因为总长度也就50条
                if (i != j && arr[i].len == arr[j].len && strcmp(arr[i].s, arr[j].s) == 0) {
                    isUnique = false;
                    break;
                }
            }
    
            if (isUnique) {
                bool isSub = false;
                for (int j = 0; j < i; j++) {
                    if (isSubsequence(arr[i].s, arr[j].s)) {
                        isSub = true;
                        break;
                    }
                }
                if (!isSub) {
                    int len = arr[i].len;
                    free(arr); // 记得提前返回的时候别内存泄漏
                    return len;
                }
            }
        }
    
        free(arr);
        return -1;
    }
    
    • 使用 combo_t 数组存储字符串和它们的长度。
    • 对数组进行排序,使得较长的字符串先被处理。
    • 遍历排序后的数组,检查每个字符串是否是唯一的。
    • 对于唯一的字符串,进一步检查它是否不是其他更长字符串的子序列。
    • 如果找到满足条件的字符串,返回它的长度;否则返回 -1。

复杂度分析

  • 时间复杂度:未优化的话是O(n^2 * m),其中 n 是字符串的数量,m 是字符串的最大长度, 可以通过仅比较相同长度字符串减小。排序的时间复杂度为 O(n log n),判断子序列的时间复杂度为 O(n * m)
  • 空间复杂度O(n * m),用于存储字符串和它们的长度。

结果

结果

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/717426.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

学习笔记——网络管理与运维——SNMP(基本配置)

四、SNMP基本配置 1、SNMP配置举例 整个华为数通学习笔记系列中&#xff0c;本人是以网络视频与网络文章的方式自学的&#xff0c;并按自己理解的方式总结了学习笔记&#xff0c;某些笔记段落中可能有部分文字或图片与网络中有雷同&#xff0c;并非抄袭。完处于学习态度&#x…

PaddleOCR学习——PP-OCR系列

相关知识前置&#xff1a; PP-LCNet PP-LCNetV3 PP-LCNetV3系列模型是PP-LCNet系列模型的延续&#xff0c;覆盖了更大的精度范围&#xff0c;能够适应不同下游任务的需要。PP-LCNetV3系列模型从多个方面进行了优化&#xff0c;提出了可学习仿射变换模块&#xff0c;对重参数…

人脸识别系统---年龄预测

一、预测年龄 1.加载预训练的人脸检测模型 face_cascade cv2.CascadeClassifier(haarcascade_frontalface_default.xml)2.加载预训练的性别和年龄识别模型 gender_net cv2.dnn.readNetFromCaffe(deploy_gender.prototxt, gender_net.caffemodel) age_net cv2.dnn.readNet…

Qwen-VL图文多模态大模型LoRA微调指南

大模型相关目录 大模型&#xff0c;包括部署微调prompt/Agent应用开发、知识库增强、数据库增强、知识图谱增强、自然语言处理、多模态等大模型应用开发内容 从0起步&#xff0c;扬帆起航。 大模型应用向开发路径&#xff1a;AI代理工作流大模型应用开发实用开源项目汇总大模…

数据可视化实验二:回归分析、判别分析与聚类分析

目录 一、使用回归分析方法分析某病毒是否与温度呈线性关系 1.1 代码实现 1.2 线性回归结果 1.3 相关系数验证 二、使用判别分析方法预测某病毒在一定的温度下是否可以存活&#xff0c;分别使用三种判别方法&#xff0c;包括Fish判别、贝叶斯判别、LDA 2.1 数据集展示&am…

软件改为开机自启动

1.按键 win R,输入“shell:startup”命令, 然后就可以打开启动目录了&#xff0c;如下&#xff1a; 2.然后&#xff0c;把要开机启动的程序的图标拖进去即可。 参考&#xff1a;开机启动项如何设置

App端接口用例设计方法和测试方法

&#x1f345; 视频学习&#xff1a;文末有免费的配套视频可观看 &#x1f345; 点击文末小卡片 &#xff0c;免费获取软件测试全套资料&#xff0c;资料在手&#xff0c;涨薪更快 前言 接口测试作为测试的重要一环&#xff0c;重点关注的是数据层面的输入输出&#xff0c;今天…

白帽子最喜欢用什么渗透测试工具?看看哪些是你用过的

一、白帽子最喜欢用什么安全工具? 2020 年的 HackerOne 黑客报告中,统计过白帽子们最喜欢用的软硬件工具。 从图中可以看到,89% 的白帽子都会使用 Burp Suite 这个 Web 应用安全测试工具,有 39% 会尝试自己写工具,第三名的 Fuzzers 是模糊测试工具。再后面主要是一些代理…

时间复杂度 空间复杂度分析

时间复杂度就是需要执行多少次&#xff0c;空间复杂度就是对象被创建了多少次。 O(1) < O(logn) < O(n) < O(nlogn) < O(n^2) < O(2^n) < O(n!) < O(n^n) 这里写目录标题 时间复杂度O(1)O(logn)、O(nlogn)O(mn)、O(m*n)最好、最坏情况时间复杂度平均情况…

SD-WAN在教育行业的应用及优势解析

随着教育领域的数字化转型&#xff0c;网络技术的需求变得愈发迫切。作为一种前沿的网络解决方案&#xff0c;SD-WAN正在为教育行业提供强有力的支持。本文将详细探讨SD-WAN在教育行业的应用&#xff0c;并分析其为教育行业带来的众多优势。 实现多校区高效互联 教育机构通常拥…

使用Multipass编译OpenHarmony工程

Multipass 是一个轻量级虚拟机管理器&#xff0c;支持 Linux、Windows 与 macOS&#xff0c;这是为希望使用单个命令提供全新 Ubuntu 环境的开发人员而设计的。使用 Linux 上的 KVM、Windows 上的 Hyper-V 和 macOS 上的 HyperKit 来以最小的开销运行 VM&#xff0c;同时它还可…

数据结构试题 16-17

先这样吧&#xff0c;&#xff0c;专业课不是统考&#xff0c;我发现每年的卷子风格都不太一样&#xff0c;侧重点也不一样。以及21的和16的发生了很大的改变。等明年1月再看看吧 那就先over啦 数据结构撒花&#xff01;&#xff01;&#xff01;&#xff01;&#xff01;&am…

Zenity向Ubuntu系统发送通知

文章目录 前言 一、Zenity是什么&#xff1f; 二、使用步骤 1.确认是否已安装 2.使用 三. 结论 前言 大家都知道&#xff0c;久坐带来的后果有多么痛苦&#xff0c;但是每天上班&#xff0c;一坐一整天&#xff0c;想着起来活动一下&#xff0c;干起活来就又忘啦&#x…

什么品牌洗地机性价比高?四大出色的王牌机型力荐

科技的发展让咱们的生活变得更加便捷&#xff0c;很多智能清洁家电的出现&#xff0c;例如洗地机&#xff0c;集合了扫地、吸尘、拖地、除菌的功能&#xff0c;帮助了我们高效地完成了家务活&#xff0c;给我们腾出了更多享受生活的时间。但&#xff0c;相信有不少的新手朋友们…

【教程】hexo 更换主题后,部署在 Github Page 无 CSS 样式

目录 前言环境hexo 更换主题解决部署到 Github Page 后无 CSS 样式的问题 前言 最近更换了 hexo 的主题后&#xff0c;重新部署到 Github Page 上发现不显示 CSS 样式&#xff0c;但在本地启动时又是正常的效果。此外&#xff0c;检查资源请求&#xff0c;发现多个 .css 文件请…

2024-6-17(沉默JVM,Spring)

1.反射 正射&#xff1a;Person person new Person(); 反射&#xff1a;我们只知道这个类的一些基本信息&#xff0c;就好像我们看电影的时候&#xff0c;为了抓住一个犯罪嫌疑人&#xff0c;警察就会问一些目击证人&#xff0c;根据这些证人提供的信息&#xff0c;找专家把…

Elasticsearch:智能 RAG,获取周围分块(一)

作者&#xff1a;来自 Elastic Sunile Manjee 在检索增强生成 (RAG) 领域&#xff0c;一个持续存在的挑战是找到输入大型语言模型 (LLM) 的最佳数据量。数据太少会导致响应不足或不准确&#xff0c;而数据太多会导致答案模糊。这种微妙的平衡启发我开发了一个专注于智能分块和利…

服务器远程桌面连接不上,服务器远程桌面连接不上的有效的解决方法

服务器远程桌面连接不上是一个常见的问题&#xff0c;可能由多种因素引起。为了解决这一问题&#xff0c;我们需要采取一系列专业的步骤进行排查和修复。 首先&#xff0c;确保本地网络连接正常。检查计算机与网络连接设备&#xff08;如路由器&#xff09;之间的物理连接&…

Linux ubuntu安装pl2303USB转串口驱动

文章目录 1.绿联PL2303串口驱动下载2.驱动安装3.验证方法 1.绿联PL2303串口驱动下载 下载地址&#xff1a;https://www.lulian.cn/download/16-cn.html 也可以直接通过CSDN下载&#xff1a;https://download.csdn.net/download/Axugo/89447539 2.驱动安装 下载后解压找到Lin…

Arcgis投影问题

今天下载数据&#xff0c;右键查看属性&#xff0c;发现只有地理坐标系&#xff0c;在arcgis里面进行展示有点丑 怎么变成下面的&#xff1f; 步骤1&#xff1a;加载数据 打开ArcGIS Pro或ArcMap。在目录窗口中&#xff0c;右键点击“文件夹连接”或“文件夹”选项&#xff0c…