字符串练习题

1.从键盘输入一个字符串,并输入一个子串,在字符串中查找子串,有子串找出子串出现的次数,并记录第一次和最后一次出现的位置

#include<stdio.h>
#include<string.h>
void fun(char *p, char *q)
{
	int len1 = strlen(q), count = 0;
	char *ret, *h;
	//子串第一次出现的位置 
	ret = strstr(p, q);
	printf("字符串首地址为:\n"); 
	printf("%p\n",p);
	printf("子串第一次出现的位置为:%p\n",ret); 
	while(ret != NULL)
	{
		count++;
		h = ret;
		ret += len1;
		ret = strstr(ret, q);
	}
	printf("子串最后一次出现的位置为:%p\n",h); 
	printf("子串出现的次数为:%d\n",count); 
	
} 

int main()
{
	char ch1[100] = "abcdecdfgcdhcb";
	char ch2[5] = "cd";
	
	fun(ch1, ch2);
	return 0;
}

2.从键盘输入一个字符串,对字符串进行逆序,使用指针

#include<stdio.h>
#include<string.h>
void fun(char *p)
{
	char *q = p + strlen(p) - 1;
	char temp;
	while(*p)
	{
		temp = *p;
		*p = *q;
		*q = temp;
		p++;
		q--;
		if(p >= q)
		{
			break;
		}
	}
} 

int main()
{
	char str[10];
	printf("请输入一个字符串:\n");
	gets(str);
	printf("字符串逆序后的结果为:\n");
	fun(str);
	puts(str); 
	return 0;
}

3.从键盘输入6个字符串进行排序

#include<stdio.h>
#include<string.h>

void sort(char (*p)[10])
{
	int i, j;
	char temp[10] = {0};
	for(i = 0; i < 6-1; i++)
	{
		for(j = 0; j < 6-1-i; j++)
		{
			if(strcmp(p[j], p[j+1]) > 0)
			{
				strcpy(temp, p[j]);
				strcpy(p[j], p[j+1]);
				strcpy(p[j+1], temp);
			}
		}
	}
}
int main()
{
	int i;
	char str[6][10] = {0};
	printf("请输入6个字符串:\n");
	for(i = 0; i < 6; i++)
	{
		scanf("%s",str[i]);
	}
	printf("排序前:\n");
	for(i = 0; i < 6; i++)
	{
		printf("%s ",str[i]);
	}
	printf("\n排序后:\n");
	sort(str);
	for(i = 0; i < 6; i++)
	{
		printf("%s ",str[i]);
	}
	return 0;
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值