码迷,mamicode.com
首页 > 编程语言 > 详细

C++ code:剩余串排列

时间:2018-05-26 11:47:06      阅读:166      评论:0      收藏:0      [点我收藏+]

标签:span   nbsp   运算   find   字符   而且   针对   space   排列   

技术分享图片

方法一:

一种直观的解是,先对第一个字串排序,然后逐个字符在第二个字串中搜索,把搜索不到的字符输出,就是所要的结果。

然而,算法库中有一个集合差运算set_difference,而且要求两个集合容器是已经排好序的。乍一看,好像是针对集合差运算来的。

技术分享图片

 1 #include<iostream>
 2 #include<fstream>
 3 #include<algorithm>
 4 using namespace std;
 5 
 6 int main()
 7 {
 8     ifstream in("remainder.txt");
 9     for (string s,t,u; in >> s >> t;u="")
10     {
11         sort(s.begin(), s.end());
12         sort(t.begin(), t.end());
13         set_difference(s.begin(),s.end(),t.begin(),t.end(),back_inserter(u));
14         cout << u << endl;
15     }
16 }

技术分享图片

技术分享图片

方法二:

然而注意到,对两个集合分别排序的代价是大的。事实上,t串无需排序,下面的解法,更高效:

 1 #include<iostream>
 2 #include<fstream>
 3 #include<algorithm>
 4 using namespace std;
 5 
 6 int main()
 7 {
 8     ifstream in("remainder.txt");
 9     for (string s,t; in >> s >> t;)
10     {
11         sort(s.begin(), s.end());
12         for (int i = 0; i < s.length();++i)
13         if (t.find(s[i]) == string::npos) cout << s[i];
14         cout <<endl;
15     }
16 }

技术分享图片

技术分享图片

 

C++ code:剩余串排列

标签:span   nbsp   运算   find   字符   而且   针对   space   排列   

原文地址:https://www.cnblogs.com/ariel-dreamland/p/9092065.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!