首页 > 其他 > 详细

5706. 句子相似性 III

时间:2021-04-04 22:27:45      阅读:15      评论:0      收藏:0      [点我收藏+]

题目链接:https://leetcode-cn.com/problems/sentence-similarity-iii/

思路:考虑怎么写最少代码最快写完 假定s1是短串 s2是长串

那么就是要满足s1的前缀是s2的前缀,s1的后缀也要是s2的后缀

那么匹配一次前缀匹配一次后缀 用下标i j 记录 当i>j 的时候 说明 长串的前后缀已经覆盖了 短串 即符合题意

可以用stringstream 读取出来单词 更快

技术分享图片
 1 class Solution {
 2     #define pb push_back
 3 public:
 4     bool areSentencesSimilar(string s1, string s2) {
 5         if(s1.size()>s2.size()) swap(s1,s2);
 6         stringstream ss1(s1),ss2(s2);
 7         string s;
 8         vector<string>a,b;
 9         while(ss1>>s) a.pb(s);
10         while(ss2>>s) b.pb(s);
11         int i=0,j=a.size()-1;
12         for(int k=0;k<b.size()&&i<a.size();k++)
13         {
14             if(a[i]==b[k]) i++;
15             else break;
16         }
17         for(int k=b.size()-1;k>=0&&j>=0;k--)
18         {
19             if(a[j]==b[k]) j--;
20             else break;
21         }
22         return i>j;
23     }
24 };
View Code

 

5706. 句子相似性 III

原文:https://www.cnblogs.com/winfor/p/14616839.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!