当前位置: 首页 > news >正文

建设网站的服务费是指什么石景山网站建设公司哪个好

建设网站的服务费是指什么,石景山网站建设公司哪个好,项目从立项到结束的流程图,官方网站查询电工证1、题目描述: 给你一个字符串 s 和一个字符串数组 dictionary ,找出并返回 dictionary 中最长的字符串,该字符串可以通过删除 s 中的某些字符得到。 如果答案不止一个,返回长度最长且字母序最小的字符串。如果答案不存在&#x…

1、题目描述:

给你一个字符串 s 和一个字符串数组 dictionary ,找出并返回 dictionary 中最长的字符串,该字符串可以通过删除 s 中的某些字符得到。

如果答案不止一个,返回长度最长且字母序最小的字符串。如果答案不存在,则返回空字符串。

示例 1:

输入:s = "abpcplea", dictionary = ["ale","apple","monkey","plea"]
输出:"apple"

示例 2:

输入:s = "abpcplea", dictionary = ["a","b","c"]
输出:"a"

提示:

  • 1 <= s.length <= 1000
  • 1 <= dictionary.length <= 1000
  • 1 <= dictionary[i].length <= 1000
  • s 和 dictionary[i] 仅由小写英文字母组成

2、代码:

高逼格代码:

class Solution {
public:string findLongestWord(string s, vector<string>& dictionary) {// 定义一个 lambda 表达式 compareStr,用于判断字典中的字符串是否是 s 的子序列auto compareStr = [&](const string& s, const string& dic) -> bool {int i = 0, j = 0; // i 遍历 s,j 遍历 dicwhile (i < s.size() && j < dic.size()) { // 双指针遍历两个字符串if (s[i] == dic[j]) { // 如果字符匹配,移动 dic 的指针++j;}++i; // 始终移动 s 的指针}return j == dic.size(); // 如果 dic 被完全匹配,返回 true};// 对字典进行排序:优先按长度降序排列,如果长度相同则按字典序升序排列sort(dictionary.begin(), dictionary.end(),[](const string& a, const string& b) {return (a.size() == b.size()) ? (a < b) : (a.size() > b.size());});// 遍历排序后的字典,找到第一个符合条件的字符串for (auto str : dictionary) {if (compareStr(s, str)) { // 如果当前字符串是 s 的子序列return str; // 返回该字符串}}// 如果没有找到符合条件的字符串,返回空字符串return "";}
};

普通代码 :

class Solution {
public:// 判断字典中的字符串 dictionary 是否是字符串 s 的子序列bool compareStr(const string& s, const string& dictionary) {int i = 0, j = 0; // i 遍历 s,j 遍历 dictionarywhile (i < s.size() && j < dictionary.size()) { // 双指针遍历两个字符串if (s[i] == dictionary[j]) { // 如果字符匹配,移动 dictionary 的指针++j;}++i; // 始终移动 s 的指针}return j == dictionary.size(); // 如果 dictionary 被完全匹配,返回 true}// 主函数:从字典中找到最长且符合条件的字符串string findLongestWord(string s, vector<string>& dictionary) {// 如果字符串 s 为空,直接返回空字符串(题目保证 s 不为空,此检查可省略)if (s == "") {return "";}// 对字典进行排序:优先按长度降序排列,如果长度相同则按字典序升序排列sort(dictionary.begin(), dictionary.end(),[](const string& a, const string& b) {if (a.size() != b.size()) // 如果长度不同,按长度降序排列return a.size() > b.size();return a < b; // 如果长度相同,按字典序升序排列});// 遍历排序后的字典,找到第一个符合条件的字符串for (auto str : dictionary) {if (compareStr(s, str)) { // 如果当前字符串是 s 的子序列return str; // 返回该字符串}}// 如果没有找到符合条件的字符串,返回空字符串return "";}
};

3、解题思路:

1.判断子序列

这是一个双指针的问题,双指针应用在哪呢?就是用在辅助函数里,来判断某个字符串是否是另一个字符串的子序列,具体方法是使用双指针,分别遍历 s 和目标字符串 dictionary,检查 dictionary是否可以通过删除 s 的某些字符得到。

2. 优化排序

为了方便比较长度和字典序,可以先对字典进行排序:优先按长度降序排列,如果长度相同则按字典序升序排列。

3. 筛选符合条件的字符串:

因为前面已经将字典进行排序,而且字典优先按长度降序排列,如果长度相同则按字典序升序排列。也就是说,第一个找到的字符串就是最符合要求的答案

http://www.dtcms.com/a/563143.html

相关文章:

  • 网站系统设计网页作业怎么做一个网站
  • 人工智能之数学基础:离散型随机变量的期望怎么计算?
  • 泉州网站wordpress 能做什么
  • 做发包业务网站ftp转换wordpress
  • 建设网站的课题wordpress怎么重新配置文件
  • 在wordpress主题后台安装了多说插件但网站上显示不出评论模块安装百度一下
  • 惠济区城乡建设局网站谷歌平台推广外贸
  • 网站收录量下降微博优惠券网站怎么做的
  • 直播网站建设无锡建设工程服务中心
  • 重庆做网站建设公司排名深圳涂料网站建设
  • 做网站好听的域名wordpress登录注册小工具
  • 网站建设基础书籍提升学历的意义
  • 网站的结构是什么样的做网站能改吗
  • a站为什么不火了企业网络营销策略有哪些
  • 广州在线图文网络科技中心网站建设创新的盐城网站开发
  • 做贷款网站犯法吗企业运营数据分析报告
  • 企业如何建自己的网站wordpress 邮箱免验证
  • 定制网站建设公司费用网站建设工具品牌
  • 整合营销活动策划方案咸阳seo
  • 不备案的网站有那些大学《网站开发与应用》试题
  • 衣服网站建设策划书网站域名备案转接入手续
  • 南宁信息建设网站佛山网约车驾驶员资格证网上报名
  • 怎么用别的网站做代理打开谷歌南京网站优化公司排名
  • 智能城市 电子商务网站建设网站建设规划文案
  • 宁波企业做网站哪家好中山建设网站首页
  • html网站免费下载个人养老保险可以补交吗
  • 网站logo设计标准没有网站如何做adsense
  • 广安做网站东莞樟木头网站制作
  • 28网站怎么做代理旅游公司网站难做吗
  • 网站建设开发案例教程视频怎么做营销推广