第四篇【找出句子中的单词 - 双指针操作】

给出一个英文的句子,找出该句子中的单词,并打印出来

用到的几个辅助函数

  • 判断字母
int isc(char t)	//判断一个字符是不是字母
{
	if((t<='z'&&t>='a')||(t<='Z'&&t>='A'))
		return 1;
	else
		return 0;
}
  • 判断单词
int isw(char t[],int b,int e)//判断字符串从下标b开始到下标e是不是一个单词
{
	int flag=1;
	for(int i=b; i<=e; i++)//下标b开始到下标e,中间有不是字母的,返回
	{
		if(isc(t[i])==0)
		{
			return 0;
		}
	}
	if(b>0)//不是字符串第一个字符
	{
		if(isc(t[b-1])==0&&isc(t[e+1])==0)//下标b-1和下标e+1不是字母,返回
		{
			return 1;
		}
	}
	else
	{
		if(isc(t[e+1])==0)
		{
			return 1;
		}
	}
	return 0;
}
  • 打印字符串指定区间字符
void prin(char t[],int b,int e)//打印字符串从下标b开始到下标e之间的内容
{
	for(int i=b; i<=e; i++)
	{
		putchar(t[i]);
	}
	printf("\n");
}

然后开始正文
我们需要用到两个指针,左指针 Left 和右指针 Right
而区间 [Left,Right] 是一个单词的话,就可以打印出来

因为有些单词只有一个字母,所以开始时Left=Right=0

找该字符串中的单词过程如下:”Are you OK?“

在这里插入图片描述
先固定左指针
接着右指针Right++,每加一次都加以判断区间 [Left,Right] 是不是一个单词

在这里插入图片描述
这样我们就能找出字符串中的第一个单词了,找到后,左指针Left++

就这样重复判断区间 [Left,Right] 是不是一个单词,就能找出字符串中的全部单词了

简单流程图
在这里插入图片描述

该算法的代码

#include<stdio.h>
#include<string.h>
#define max 150	//句子总单词数最大值 
#define lmax 25 //句子单个单词字母总数最大值 
int isc(char t)	//判断一个字符是不是字母
{
	if((t<='z'&&t>='a')||(t<='Z'&&t>='A'))
		return 1;
	else
		return 0;
}
int isw(char t[],int b,int e)//判断字符串从下标b开始到下标e是不是一个单词
{
	int flag=1;
	for(int i=b; i<=e; i++)//下标b开始到下标e,中间有不是字母的,返回
		if(isc(t[i])==0)
			return 0;
	if(b>0)//不是字符串第一个字符
	{
		if(isc(t[b-1])==0&&isc(t[e+1])==0)//下标b-1和下标e+1不是字母,返回
			return 1;
	}
	else
		if(isc(t[e+1])==0)
			return 1;
	return 0;
}
void prin(char t[],int b,int e)//打印字符串从下标b开始到下标e之间的内容
{
	for(int i=b; i<=e; i++)
		printf("%c",t[i]);
	printf("\n");
}
int main()
{
	char t[max]= {' '};
	char wt[max][lmax];
	while(t)
	{
		printf("输入quit退出\n");
		fflush(stdin);
		gets(t);
		if(strcmp(t,"quit")==0)
			break;
		int count=0;
		int len=strlen(t);
		int Left=0,Right=0;//左指针Left,右指针Right 
		for(Left=0; Left<len; Left++)
		{
			for(Right=0; Right<len-Left; Right++)
			{
				if(isw(t,Left,Left+Right)==1)//判断从左指针到右指针,之间是不是一个单词 
				{
					prin(t,Left,Left+Right);
					count ++;
					break;
				}
			}
		}
		printf("\n单词数:%d\n\n",count);
	}
	return 0;
}

测试截图在这里插入图片描述
在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

fuill

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值