| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 2087 人关注过本帖
标题:问一下,我想输入一串字符删除字母a后输出,就像输入‘ancd’得到‘ncd’这 ...
只看楼主 加入收藏
huat107
Rank: 1
等 级:新手上路
帖 子:37
专家分:0
注 册:2012-11-18
结帖率:92.31%
收藏
已结贴  问题点数:5 回复次数:12 
问一下,我想输入一串字符删除字母a后输出,就像输入‘ancd’得到‘ncd’这样子啊
虚心求教~~
搜索更多相关主题的帖子: 字母 
2012-11-24 16:37
ltianc
Rank: 3Rank: 3
等 级:论坛游侠
帖 子:56
专家分:128
注 册:2012-10-16
收藏
得分:0 
#include<stdio.h>
#include<string.h>
#define MAXSIZE 225

typedef struct
{
    char str[MAXSIZE];
    int length;
} SeqString;

int StrDelete(SeqString *S, int i, int len)
{
    int k;
    if(i < 1 || i > S->length || i - 1 + len > S->length)
        return 0;
    else
    {
        for(k = i - 1 + len; k < S->length; k++)
            S->str[k - len] = S->str[k];
        S->length = S->length - len;
        S->str[S->length] = '\0';
    }
    printf("删除之后的字符串:");
    printf("%s\n", S->str);

    return 0;

}
int main(void)
{
    SeqString s1;
    int i, length;

    printf("请输入源子串:");
    scanf("%s", s1.str );
    printf("字符串长度为:%d\n", s1.length = strlen(s1.str ));
    printf("请输入要删除的位置:");
    scanf("%d", &i);
    printf("请输入删除的长度:");
    scanf("%d", &length);
    StrDelete(&s1, i, length);
}
你试试。

世界等我去改变。
2012-11-24 16:47
ltianc
Rank: 3Rank: 3
等 级:论坛游侠
帖 子:56
专家分:128
注 册:2012-10-16
收藏
得分:0 
#include<stdio.h>
#include<string.h>
#define MAXSIZE 225

typedef struct
{
    char str[MAXSIZE];
    int length;
} SeqString;

int StrDelete(SeqString *S, int i, int len)
{
    int k;
    if(i < 1 || i > S->length || i - 1 + len > S->length)
        return 0;
    else
    {
        for(k = i - 1 + len; k < S->length; k++)
            S->str[k - len] = S->str[k];
        S->length = S->length - len;
        S->str[S->length] = '\0';
    }
    printf("删除之后的字符串:");
    printf("%s\n", S->str);

    return 0;

}
int main(void)
{
    SeqString s1;
    int i, length;

    printf("请输入源子串:");
    scanf("%s", s1.str );
    printf("字符串长度为:%d\n", s1.length = strlen(s1.str ));
    printf("请输入要删除的位置:");
    scanf("%d", &i);
    printf("请输入删除的长度:");
    scanf("%d", &length);
    StrDelete(&s1, i, length);
}
你试试。

世界等我去改变。
2012-11-24 16:47
huat107
Rank: 1
等 级:新手上路
帖 子:37
专家分:0
注 册:2012-11-18
收藏
得分:0 
这么高级,我都还没学过呢!
2012-11-24 16:51
TonyDeng
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
等 级:贵宾
威 望:304
帖 子:25859
专家分:48889
注 册:2011-6-22
收藏
得分:0 
循环一遍字符串,逐个字符输出——过滤掉不需要的字符不输出即可。

授人以渔,不授人以鱼。
2012-11-24 16:55
BMN李
Rank: 2
等 级:论坛游民
帖 子:15
专家分:39
注 册:2012-11-21
收藏
得分:5 
#include <stdio.h>
void main()
{
    char str[20];
    int i;
    printf("请输入一串字符:");
    scanf("%s",str);
    printf("删除字母a后输出:");
    for(i=0;str[i]!='\0';i++)
    {
        if(str[i]=='a')  continue;
        printf("%c",str[i]);
    }
    printf("\n");
}
2012-11-24 17:35
photon
Rank: 1
等 级:新手上路
帖 子:2
专家分:0
注 册:2012-11-24
收藏
得分:0 
回复 2楼 ltianc
我觉得要用结构体的话还是把操作封装在结构体中比较好!你觉得呢?
2012-11-24 17:39
TonyDeng
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
等 级:贵宾
威 望:304
帖 子:25859
专家分:48889
注 册:2011-6-22
收藏
得分:0 
以下是引用BMN李在2012-11-24 17:35:00的发言:

#include
void main()
{
    char str[20];
    int i;
    printf("请输入一串字符:");
    scanf("%s",str);
    printf("删除字母a后输出:");
    for(i=0;str!='\0';i++)
    {
        if(str=='a')  continue;
        printf("%c",str);
    }
    printf("\n");
}

结构化编程,不需要使用continue:
程序代码:
void main()
{
    char str[20];
    int i;
    printf("请输入一串字符:");
    scanf("%s",str);
    printf("删除字母a后输出:");
    for(i=0;str!='\0';i++)
    {
        if(str!='a')
        {
            printf("%c",str);
        }
    }
    printf("\n");
}

授人以渔,不授人以鱼。
2012-11-24 17:47
embed_xuel
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
等 级:贵宾
威 望:58
帖 子:3845
专家分:11385
注 册:2011-9-13
收藏
得分:0 
回复 8楼 TonyDeng
顶你,前两天有个人要做输入n个数,最后输出最大值,一帮人回复用冒泡等各种排序算法,把简单事情复杂化

总有那身价贱的人给作业贴回复完整的代码
2012-11-24 18:10
ren613
Rank: 3Rank: 3
来 自:宣武
等 级:论坛游侠
帖 子:117
专家分:120
注 册:2012-11-20
收藏
得分:0 
支持简单编程

天道酬勤
2012-11-24 18:25
快速回复:问一下,我想输入一串字符删除字母a后输出,就像输入‘ancd’得到‘nc ...
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.016252 second(s), 7 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved