| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 2172 人关注过本帖
标题:一道题不会做,谁来帮帮我啊
只看楼主 加入收藏
linweihong
Rank: 1
等 级:新手上路
帖 子:11
专家分:0
注 册:2008-6-6
收藏
 问题点数:0 回复次数:23 
一道题不会做,谁来帮帮我啊
编一个C程序,把一行字符串中的所有单词倒序 例:" you are a good student"
                                         结果:"student good a are you"
希望高手帮帮忙啊!
小弟在此谢过
搜索更多相关主题的帖子: 单词 字符串 
2008-09-04 09:41
wNumberOney
Rank: 1
等 级:新手上路
帖 子:25
专家分:0
注 册:2008-7-12
收藏
得分:0 
应该是用gets将字符串读入栈,再从栈中输出
2008-09-04 10:15
josen0205
Rank: 2
来 自:江苏
等 级:论坛游民
帖 子:307
专家分:52
注 册:2007-5-8
收藏
得分:0 
#include <stdio.h>
#include <string.h>


int main(int argc, char *argv[])
{
    int i = 0, icount = 0;
    char sbuf[2048+1], tbuf[2048+1];
    char sword[128][256];
    char *p;

    memset(sbuf, 0x00, sizeof(sbuf));
    memset(tbuf, 0x00, sizeof(tbuf));

    printf("Please Enter your string: ");
    gets(sbuf);

    i = 0;
    for(;;)
    {
        if(0 == i)
            p = strtok(sbuf, " ");
        else
            p = strtok(NULL, " ");
        if(NULL == p)
            break;
        strcpy(sword[i], p);
        i ++;
    }
    icount = i;

    if(0 >= icount)
        return 0;

    for(i = icount -1; i >=0; i --)
        sprintf(tbuf+strlen(tbuf), "%s ", sword[i]);

    printf("%s\n", tbuf);

    return 0;
}

只有想不到,没有做不到
2008-09-04 10:28
StarWing83
Rank: 8Rank: 8
来 自:仙女座大星云
等 级:贵宾
威 望:19
帖 子:3951
专家分:748
注 册:2007-11-16
收藏
得分:0 
广陵?广陵?你大显身手的时候到了……

专心编程………
飞燕算法初级群:3996098
我的Blog
2008-09-04 11:20
iFreeBSD
Rank: 4
等 级:业余侠客
威 望:4
帖 子:474
专家分:236
注 册:2007-11-5
收藏
得分:0 
[bo][un]StarWing83[/un] 在 2008-9-4 11:20 的发言:[/bo]

广陵?广陵?你大显身手的时候到了……

关注。

without further ado, let’s get started
2008-09-04 11:29
广陵绝唱
Rank: 10Rank: 10Rank: 10
等 级:贵宾
威 望:29
帖 子:3607
专家分:1709
注 册:2008-2-15
收藏
得分:0 
广陵驾到,代码还很不成熟,还望各位指教。谢谢。
程序代码:
/*******************************************************************************

        编一个C程序,把一行字符串中的所有单词倒序 例:" you are a good student"
                                         结果:"student good a are you"


*******************************************************************************/
#include<stdio.h>
#include<string.h>
#define N 200
int main(void)
{
    int i,j,k,n,l1=0,l2;
    char a[N],b[N][N];
    n=strlen(a);
    printf("please input:\n");
    gets(a);
    for(i=0;i<n;i++)
        for(j=i+1;j<n;j++)
        {
            l2=0;
            if(a[j]==32||a[j]==0)
            {
                for(k=i;k<j;k++)
                {
                    b[l1][l2]=a[k];
                    l2++;
                }
                b[l1][l2]='\0';
                l1++;
                i=j;
                break;
             }
        }
    for(i=l1-1;i>=0;i--)
    {
        for(j=0;b[i][j]!='\0';j++)
            printf("%c",b[i][j]);
        printf(" ");
    }

    getch();
}

2008-09-04 18:01
linweihong
Rank: 1
等 级:新手上路
帖 子:11
专家分:0
注 册:2008-6-6
收藏
得分:0 
回复 3# josen0205 的帖子
谢谢帮我解决
2008-09-04 18:40
linweihong
Rank: 1
等 级:新手上路
帖 子:11
专家分:0
注 册:2008-6-6
收藏
得分:0 
回复 6# 广陵绝唱 的帖子
六楼的运行没有结果哦
2008-09-04 18:44
广陵绝唱
Rank: 10Rank: 10Rank: 10
等 级:贵宾
威 望:29
帖 子:3607
专家分:1709
注 册:2008-2-15
收藏
得分:0 
回复 8# linweihong 的帖子
我用的是WIN-TC编译器,我的结果是正常的。呵。
2008-09-04 20:35
awnucel
Rank: 1
等 级:新手上路
威 望:1
帖 子:68
专家分:0
注 册:2006-12-13
收藏
得分:0 
用递归做的,可能还可以简化,你看一下吧
#include "stdio.h"
void prit(char *s)
{
    char *p;
    int n=0,l=0,i;
    n = strlen(s);
    for(i=0;i<n;i++)
    {
       if(s[i] == ' ')
       {
          l=i;
       }
    }
    if(l==0)
    {
        printf("%s\n",s);
        return;
    }
    else
    {
        p=&s[l+1];
        printf("%s ",p);
    }
    s[l]='\0';
    prit(s);
}
void main()
{
    char s[50];
    int n,i,l=0;
    gets(s);
    prit(s);
    getch();
}
2008-09-05 05:02
快速回复:一道题不会做,谁来帮帮我啊
数据加载中...
 
   



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

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