PTA习题8-6 删除字符

本题要求实现一个删除字符串中的指定字符的简单函数。

函数接口定义:

void delchar( char *str, char c );

其中char *str是传入的字符串,c是待删除的字符。函数delchar的功能是将字符串str中出现的所有c字符删除。

裁判测试程序样例:

#include <stdio.h>
#define MAXN 20

void delchar( char *str, char c );
void ReadString( char s[] ); /* 由裁判实现,略去不表 */

int main()
{
    char str[MAXN], c;

    scanf("%c\n", &c);
    ReadString(str);
    delchar(str, c);
    printf("%s\n", str);

    return 0;
}

/* 你的代码将被嵌在这里 */

输入样例:

a
happy new year

输出样例:

hppy new yer

解题思路,每次删除一个字符,后面的要跟上来(备胎上位)。可借用strcat(需要加string的头文件);或者传统的补位赋值: 

void delchar( char *str, char c ) {
    char* p=str;
    //借用字符串函数strcat;
//    while (*p!='\0') {
//        if (*p==c) {
//            *p='\0';
//            char *q=p+1;
//            strcat(str,q);
//            p--;
//        }
//        p++;
//    }
    //另一种解法,补位
	while (*p!='\0') {
		if ( *p==c ) {
			char* q=p;
			while (*q!='\0') {
				*q=*(q+1);
				q++;
			}
			p--;
		}
		p++;
	} 
}

删除发生时,指针应该不动,接着删除及移位后继续判断,用p--和p++抵掉。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值