C++ code:剩余串排列

方法一:

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

然而,算法库中有一个集合差运算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 }

 

posted @ 2018-05-26 10:24  Ariel_一只猫的旅行  阅读(263)  评论(0编辑  收藏  举报