鱼C论坛

 找回密码
 立即注册
查看: 1470|回复: 2

[已解决]编写函数squeeze(s1,s2),将字符串s1中任何与字符串s2中匹配的字符都删除

[复制链接]
发表于 2018-10-19 21:16:03 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
C语言,编写函数squeeze(s1,s2),将字符串s1中任何与字符串s2中匹配的字符都删除

程序如下,书上的题目,我先自己做了一遍感觉循环那出了问题,改了好多遍都没成功,自己百度搜索相关题目,感觉不是一种写法,对比之后还是检查不出来(水平有限,感觉我逻辑很差 ),请大佬们帮帮忙,看看程序问题出现在哪里。感激感激
#include <stdio.h>

void squeeze(char s1[], char s2[]);

int main()
{
    char s1[] = {'a','b','c','d','e','f','g','h','i','k',0};
    char s2[] = {'b','c','e','g','i',0};
    
    squeeze(s1, s2);
    printf("%s \n", s1);
    return 0;
}

void squeeze(char s1[], char s2[])
{
    int i, j, k;
    i = j = k = 0;

        for(i;s1[i]!='\0';i++)
        {k++;
                for(j;s2[j]!='\0';j++)
                {
                        if(s1[i]!=s2[j])
                                s1[k]=s1[i];
                        else
                                s1[k]='\0';
                }
                
        }
    
  
}
最佳答案
2018-10-19 22:02:55
#include <stdio.h>

void squeeze(char s1[], char s2[]);

int main()
{
    char s1[] = {'a','b','c','d','e','f','g','h','i','k',0};
    char s2[] = {'b','c','e','g','i',0};
    
    squeeze(s1, s2);
    printf("%s\n", s1);
    return 0;
}

void squeeze(char s1[], char s2[])
{
    for(int i = 0; s1[i] != '\0'; i++)
    {
        for(int j = 0; s2[j] != '\0'; j++)
        {
            if(s1[i] == s2[j])
            {
                for(int k = i; s1[k] != '\0'; k++)
                    s1[k] = s1[k+1];
                i--;
                break;
            }
        }
    }
}
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2018-10-19 22:02:55 | 显示全部楼层    本楼为最佳答案   
#include <stdio.h>

void squeeze(char s1[], char s2[]);

int main()
{
    char s1[] = {'a','b','c','d','e','f','g','h','i','k',0};
    char s2[] = {'b','c','e','g','i',0};
    
    squeeze(s1, s2);
    printf("%s\n", s1);
    return 0;
}

void squeeze(char s1[], char s2[])
{
    for(int i = 0; s1[i] != '\0'; i++)
    {
        for(int j = 0; s2[j] != '\0'; j++)
        {
            if(s1[i] == s2[j])
            {
                for(int k = i; s1[k] != '\0'; k++)
                    s1[k] = s1[k+1];
                i--;
                break;
            }
        }
    }
}
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2018-10-22 20:06:50 | 显示全部楼层
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-10-2 18:24

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表