字符串转换为单词,重复单词删除

博客内容讲述了如何将字符串拆分成单词,移除重复项,并根据单词长度升序排列的过程。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

字符串转换为单词,重复单词删除并且按照单词长度递增输出

#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;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值