c++的一个程序问题
#include<iostream>
#include<fstream>
#include<vector>
#include<string>
#include<algorithm>
using namespace std;
//用于将单词长度排序的比较函数
bool isshorter(const string &s1, const string &s2)
{
return s1.size()<s2.size();
}
//测试给定string对象的长度是否与其边界相匹配
class BET_cls{
public:
BET_cls(string::size_type len1,string::size_type len2)
{
if(len1<len2)
{
minlen=len1;
maxlen=len2;
}
else{
minlen=len2;
maxlen=len1;
}
}
bool operator()(const string &s)
{
return s.size()>=minlen && s.size()<+maxlen;
}
private:
string::size_type minlen;
string::size_type maxlen;
};
//如果ctr不为1,返回word的复制版本
string make_plural (size_t ctr,const string &word,const string &ending)
{
return (ctr==1)?word:word+ending;
}
//main函数接受文件名为参数
int main(int argc,char **argv)
{
//检查命令行的个数
if(argc<2)
{
cerr<<"no input file!"<<endl;
return EXIT_FAILURE;
}
//打开文件
ifstream infile;
infile.open(argv[1]);
if(!infile)
{
cerr<<"can not open input file"<<endl;
return EXIT_FAILURE;;
}
vector<string> words;
string word;
while(infile>>word)
words.push_back(word);
//对输入排序以便去除重复单词
sort(words.begin(),words.end());
//使用unique对元素重新排序并返回一个迭代器
//表示无重复单词范围结束
//erase操作删除重复的单词
words.erase(unique(words.begin(),words.end()),words.end());
//计算输出长度在1到10之间的单词数量
vector<string>::size_type wc=count_if(words.begin(),words.end(),BET_cls(1,10));
cout<<wc<<" "<<make_plural(wc,"word","s")<<endl;
return 0;
}
请问这个程序如何运行??