字符串转换为单词,重复单词删除并且按照单词长度递增输出
#include<iostream>
#include<string>
#include<map>
#include<string>
using namespace std;
int main()
{
//string s="some local buses,some1234drivers";
string s;
cin>>s;
char*s1=(char*)s.c_str();//将string转换为char*,必须加强制转换否则会显示const char*不能转换为char*;
int size=strlen(s1);
for (int i=0;i<size;i++)
{
if (s1[i]<'A'||(s1[i]>'Z'&&s1[i]<'a')||s1[i]>'z')
{
s1[i]=',';
}
}
char *index=",";
char *word[10];
char*p;
p=strtok(s1,index);
//分解字符串为一组字符串。s为要分解的字符串,delim为分隔符字符串。
//首次调用时,s指向要分解的字符串,之后再次调用要把s设成NULL。
//strtok()用来将字符串分割成一个个片段。参数s指向欲分割的字符串,
//参数delim则为分割字符串中包含的所有字符。当strtok()在参数s的字符串中发现参数delim中包含的分割字符时,
//则会将该字符改为\0 字符。在第一次调用时,strtok()必需给予参数s字符串,往后的调用则将参数s设置成NULL。
//每次调用成功则返回指向被分割出片段的指针。
int j=0;
while (p!=NULL)
{
word[j]=p;
p=strtok(NULL,index);
j++;
}
if (j==0)
{
cout<<" "<<endl;
return 0;
}
for (int k=0;k<j;k++)
{
for (int m=k+1;m<j;m++)
{
if (strcmp(word[k],word[m])==0)
{
word[m]="\0";
}
}
}
multimap<int,char*>mic;
for (int q=0;q<j;q++)
{
mic.insert(make_pair(strlen(word[q]),word[q]));
}
multimap<int,char*>::iterator it=mic.begin();
while (it!=mic.end())
{
if (it->first!=0&&(it!=(--mic.end())))
{
cout<<it->second<<" ";
}
else
{
cout<<it->second;
}
it++;
}
cout<<endl;
}