【LintCode】892.外星人字典

题目

描述

有一种新的使用拉丁字母的外来语言。但是,你不知道字母之间的顺序。你会从词典中收到一个 非空的 单词列表,其中的单词在这种新语言的规则下按字典顺序排序。请推导出这种语言的字母顺序。

注意:

  1. 你可以假设所有的字母都是小写。
  2. 如果字符串 a 是字符串 b 的前缀,且 b 出现在 a 之前,那么这个顺序是无效的。
  3. 如果顺序是无效的,则返回空字符串。
  4. 这里可能有多个有效的字母顺序,返回以正常字典顺序看来最小的。
  5. 一个字符串中的字母默认是同一等级的,且按照人类字典序排序。

样例

样例1

输入:["wrt","wrf","er","ett","rftt"]
输出:"wertf"
解释:
从 "wrt""wrf" ,我们可以得到 't'<'f'"wrt""er" ,我们可以得到'w'<'e'"er""ett" ,我们可以得到 get 'r'<'t'"ett""rftt" ,我们可以得到 'e'<'r'
所以返回 "wertf"

样例2:

输入:["z","x"]
输出:"zx"
解释:
从 "z""x",我们可以得到 'z' < 'x'
所以返回"zx"

原题链接

892.外星人字典

思路

先比较相邻的字符串,能生成一条边,如"bck" “bak”,根据顺序可生成一条 c 指向 a 的边,即c->a。

根据这些生成的边得到一个图,再对该图进行拓扑排序

更详细的分析见 Leetcode 269.火星词典

代码

class Solution {
public:/*** @param words: a list of words* @return: a string which is correct order*/string alienOrder(vector<string> &words) {if (words.size() == 0) return "";unordered_map<char, int> indegree; //入度表//如果a->b,则b的入度为1for (int i = 0; i < words.size(); i++) {for (char c : words[i]) {indegree[c] = 0; //初始时,所有字符的入度都为0}}//比如a->b,a->c,则key为a,value为{b, c}//记录字符的后继字符(邻居)unordered_map<char, unordered_set<char>> graph;for (int i = 0; i < words.size() - 1; i++) {//比较相邻字符串(当前字符串和下一个字符串),找边string cur = words[i];string next = words[i + 1];//需要比较的长度是两个字符串中较小的长度,重叠的部分才有可能产生边//如bck和bckf只需要比较3个字符长度即可,int len = min(cur.size(), next.size()); int j = 0;for (; j < len; j++) {if (cur[j] != next[j]) { //找到一条边如absfk和abcf,找到一条边s->cif (!graph[cur[j]].count(next[j])) { //同一条边不要重复加入度graph[cur[j]].insert(next[j]);indegree[next[j]]++; }break; //找到一条边就跳出当前循环}}if (j < cur.size() && j == next.size()) { //cur的长度 > next的长度,如bckf 和 bck,这种情况就无字典序return "";}}//拓扑排序string ans;priority_queue<char, vector<char>, greater<char>> que;for (auto it : indegree) {if (it.second == 0) { //所有入度为0的点先入队que.push(it.first);} }while (!que.empty()) {char cur = que.top();que.pop();ans += cur;if (graph.count(cur)) { for (char next : graph[cur]) { if (--indegree[next] == 0) { //cur的邻居的入度全部减1,再将邻居入度为0的入队que.push(next); }}}}//如"zy""zx",应该输出"yxz"//"ad","abc"应该输出"abcd"return ans.size() == indegree.size() ? ans : "";}
};

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

MSSQL-识别扩展extended event(扩展事件)中的时间单位

经常使用sqlserver extended event(扩展事件)&#xff0c;但是总是忘记扩展事件使用的时间单位&#xff0c;不确定它们是 秒、毫秒、还是微秒&#xff1f; 以下下代码能够从 相关DMV中提取description字段内容来识别时间单位&#xff1a; SELECT [p].[name] [package_name],[o…

07. 面向对象编程(一)

目录 1、前言 2、类和对象 2.1、定义类 2.2、定义方法 2.3、创建对象 2.4、访问控制 2.4.1、公共变量 2.4.2、私有变量 2.4.3、保护成员 2.4.4、总结 3、封装 4、继承 5、多态 6、小结 1、前言 在Python中&#xff0c;面向对象编程&#xff08;Object-Oriented …

Hoppscotch (PostWoman)调试工具的介绍及详细使用方法

Postwoman是一款强大的API调试工具&#xff0c;可通过用户友好的界面发送和接收HTTP请求&#xff0c;以及测试和调试API端点。 以下是Postwoman的详细使用方法&#xff1a; 直接启动Hoppscotch &#xff1a; 在浏览器中打开Hoppscotch 的官方网站&#xff1a;Hoppscotch • Op…

vuex的初步使用-1

1. 介绍 Vuex 是一个 Vue 的 状态管理工具&#xff0c;状态就是数据。 简单讲&#xff1a;Vuex 就是一个插件&#xff0c;可以帮我们管理 Vue 通用的数据 (多组件共享的数据)。相对于一个仓库&#xff1a;存放组件共享的数据。 2. 安装 vuex 安装vuex与vue-router类似&…

C语言第六十一弹---求最小公倍数

使用C语言求最小公倍数 定义:两个或多个整数公有的倍数叫做它们的公倍数,其中除0以外最小的一个公倍数就叫做这几个整数的最小公倍数。 方法一:乘积/最大公因数法 已知 最小公倍数 整数乘积 / 最大公因数 思路:使用辗转相除法,获取最大公因数,然后使用整数乘积除以最大公因…

SpringMVC下半篇之拦截器

学习目标 拦截器文件上传异常处理器ssm整合 1.拦截器 1.1.什么是拦截器&#xff1f; ​ Spring MVC中的拦截器&#xff08;Interceptor&#xff09;类似于Servlet中的过滤器&#xff08;Filter&#xff09;&#xff0c;它主要用于拦截用户请求并作相应的处理。例如通过拦截…

基于Mapbox的Mvt矢量瓦片集成实践

目录 前言 一、数据说明 1、基本数据 2、属性数据 二、Mapbox集成Mvt矢量瓦片 1、关于访问令牌 2、定义html 3、初始地图 4、加载矢量瓦片 5、效果展示 总结 前言 熟悉矢量瓦片的朋友一定知道&#xff0c;在Webgis当中&#xff0c;矢量瓦片的格式除了pbf的格式&#x…

前端已死,我们的出路究竟在哪里?

最近前端已死这个话题很火&#xff0c;同时带来的社会效应也很大。在外行看来&#xff0c;以为市场上已经不需要前端了&#xff0c;原本要入行的朋友们也不敢入行了&#xff1b;对于已经入行的朋友们&#xff0c;也会因为这句话增添几分焦虑。 那么前端这个行业的现状到底如何…

UE5 C++的TCP服务器与客户端

客户端.h 需要在Build.cs中加入模块:"Networking","Sockets","Json","JsonUtilities" // Fill out your copyright notice in the Description page of Project Settings.#pragma once#include "CoreMinimal.h" #include…

c++八股8

友元函数能不能是虚函数&#xff1a; 友元函数不属于类的成员函数&#xff0c;它独立于类存在&#xff0c;因此不存在是否为虚函数的概念。友元函数主要用于突破类的封装性&#xff0c;使外部函数能访问类的私有和保护成员&#xff0c;它与类的继承和多态无关。TCP三握四挥&…

SQL进阶2

5、检查CHECK约束 CHECK 约束主要用于通过将插入的值限制为遵循定义的值、范围或格式规则的值来强制域完整性。 5.1 CHECK 约束&#xff08;检查性约束&#xff09;用来限制字段的取值范围。 在 CHECK 约束中添加限制条件&#xff0c;只有满足这些条件的值才允许进入该字段。 …

媒体捕捉-iOS中的人脸识别

引言 在如今的移动应用和直播场景中&#xff0c;我们常常能体验到一种颇具趣味与互动性的功能&#xff1a;无论是美颜相机中的萌趣贴纸精准附着于人脸关键点上&#xff0c;还是主播们在直播时实时戴上可爱的虚拟动物耳朵或动态装饰物&#xff0c;这些令人眼前一亮的效果背后&a…

Redis的常用场景有哪些?

1、缓存 缓存现在几乎是所有中大型网站都在用的必杀技&#xff0c;合理的利用缓存不仅能够提升网站访问速度&#xff0c;还能大大降低数据库的压力。Redis提供了键过期功能&#xff0c;也提供了灵活的键淘汰策略&#xff0c;所以&#xff0c;现在Redis用在缓存的场合非常多。 …

算法训练营Day42

#Java #动态规划 # Feeling and experiences&#xff1a; 买卖股票的最佳时机III&#xff1a;力扣题目链接 给定一个数组&#xff0c;它的第 i 个元素是一支给定的股票在第 i 天的价格。 设计一个算法来计算你所能获取的最大利润。你最多可以完成 两笔 交易。 注意&#x…

docker:环境安装

系列文章目录 docker&#xff1a;环境安装 文章目录 系列文章目录前言一、Debian安装1.镜像下载2.VM安装3.Debian安装 二、docker安装1.Debian12换源2.docker安装3.docker测试4.docker换源 总结 前言 因为CentOS7确定停服时间为6月30日&#xff0c;虽然对我这种小虾米没啥影响…

dubbox框架

1、dubbox介绍 Dubbo(读音[ˈdʌbəʊ])是阿里巴巴公司开源的一个基于Java的高性能RPC&#xff08;Remote Procedure Call&#xff09;框架&#xff0c;使得应用可通过高性能的 RPC 实现服务的输出和输入功能&#xff0c;可以和 Spring框架无缝集成。后期阿里巴巴停止了该项目…

机器学习之样本及统计量

在数理统计中,称研究对象的全体为总体,组成总体的每个基本单元叫个体。从总体X中随机抽取一部分个体 X 1 , X 2 , . . . , X N X_1,X_2,...,X_N X1​,X2​,...,XN​称 X 1 , X 2 , . . . , X N X_1,X_2,...,X_N X1​,X2​,...,XN​为取自X的容量为n的样本。 实际上,数理统计…

HashMap集合万字源码详解(面试常考)

文章目录 HashMap集合1.散列2.hashMap结构3.继承关系4.成员变量5.构造方法6.成员方法6.1增加方法6.2将链表转换为红黑树的treeifyBin方法6.3扩容方法_resize6.3.1扩容机制6.3.2源码resize方法的解读 6.4 删除方法(remove)6.5查找元素方法(get)6.6遍历HashMap集合几种方式 7.初始…

vue安装组件报错In most cases you are behind a proxy or have bad network settings.

解决办法 步骤1 npm config get proxy npm config get https-proxy 如果2个返回值不为null&#xff0c;请执行下面代码&#xff0c;重置为null。否则&#xff0c;直接执行步骤2。 npm config set proxy null npm config set https-proxy null 步骤2 npm config set regis…

cv 不能正常读取中文路径

之前一直以为是PyQT的getOpenFileNames方法不能读取中文路径的。多次尝试后发现不是&#xff0c;是OpenCV的问题。 self.selected_imgPaths, _ QtWidgets.QFileDialog.getOpenFileNames(self, "打开图片", "./pending_images", "*.jpg;;*.JPG;;*.png…