标题:字符串处理
取消只看楼主
panzer22054
Rank: 1
等 级:新手上路
帖 子:9
专家分:0
注 册:2017-7-19
结帖率:100%
已结贴  问题点数:18 回复次数:5 
字符串处理

我写的程序,哪里错了,该怎么改


【问题描述】

输入一个字符串,从头到尾搜索,凡搜索到前面已出现过的相同单词,就删除。也就是说,在这个字符串中,每个单词只能出现一次。

【样例】

输入:Where there is a will , there is a way

输出:Where there is a will , way




#include<stdio.h>
#include "string.h"
#include <stdlib.h>
int main()
{
    char a[1000],*p[30],*q,*t;
    int i;
    gets(a);
    q=a;
    for(i=0;i<30;i++)
    {
        
        t= (char *)malloc(15);
        int j=0;
        while(*q)
        {
            
            t[j]=*q;
            j++;
            if(*q==32)
            {
                t[j]=0;
                q++;
                break;
               
            
            }
            
            q++;
        }
        if(*q==0)
            t[j]=0;
        if(i==0)
        {
   
            p[i]=t;
        continue;
        }
        for(int k=0;k<i;k++)
        {
            if(strcmp(p[k],t)==0)
                i-=1;
            else
                p[i]=t;
            
            
            
        }
        
   
        if(!*q)
            break;
    }
   
 for(int k=0;k<=i;k++)
 {
      printf("%s\n",p[i]);
 free(p[k]);
 }
}









搜索更多相关主题的帖子: 字符串 处理 include int for 
2017-08-01 10:10
panzer22054
Rank: 1
等 级:新手上路
帖 子:9
专家分:0
注 册:2017-7-19
得分:0 
回复 2楼 GBH1
我刚开始也是这样想的,先提取出来然后比较重组,后来他们建议我说在提取的同时就进行比较然后直接放入指针数组中再重组一下就是了。我就按他们说的做了,谢谢啦,我调试出来了。
2017-08-01 12:03
panzer22054
Rank: 1
等 级:新手上路
帖 子:9
专家分:0
注 册:2017-7-19
得分:0 
回复 3楼 九转星河
算是新手,数据结构基本上没学过但是概念懂一些。我会去看看的,不懂得还请不吝赐教啊,嘿嘿
2017-08-01 12:06
panzer22054
Rank: 1
等 级:新手上路
帖 子:9
专家分:0
注 册:2017-7-19
得分:0 
回复 4楼 rjsp
单词是以空格结尾,所以我判断的时候拿空格的ASC判断的,这个输入单词量题目没限制,自己定义就好了
2017-08-01 12:08
panzer22054
Rank: 1
等 级:新手上路
帖 子:9
专家分:0
注 册:2017-7-19
得分:0 
我修改了一下,把重复的都去掉了剩下的就是把单词按顺序组装起来,我就没加上去,可以自己写一下。欢迎各位指点
我的思路就是提取单词的同时作比较,然后相同的单词不放入指针数组中。


#include<stdio.h>
#include "string.h"
#include <stdlib.h>
int main()
{
    char a[1000],*p[30],*q,*t;
    int i;
    gets(a);
    q=a;
    for(i=0;i<30;i++)
    {
        
        t= (char *)malloc(15);
        int j=0;
        while(*q)
        {
            
            t[j]=*q;
            j++;
            if(*q==32)
            {
                t[j]=0;
                q++;
                break;
               
            
            }
            
            q++;
        }
        if(*q==0)
        {
            
        t[j]=32;
            t[j+1]=0;
        }
        if(i==0)
        {
   
            p[i]=t;
        continue;
        }
        int s=i;
        for(int k=0;k<i;k++)
        {
            if(strcmp(p[k],t)==0)
            {
               
            i-=1;
                continue;
            }
            
            
        }
        if(s==i)
            p[i]=t;
   
        if(!*q)
            break;
    }
   
 for(int k=0;k<=i;k++)
 {
      printf("%s\n",p[k]);
 free(p[k]);
 }
}

2017-08-01 12:10
panzer22054
Rank: 1
等 级:新手上路
帖 子:9
专家分:0
注 册:2017-7-19
得分:0 
回复 9楼 rjsp
表示没学c++,看不懂啊。。。明天才要学c#.
2017-08-01 12:42



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-479732-1-1.html




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

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