题解 | #句子逆序#

句子逆序

https://www.nowcoder.com/practice/48b3cb4e3c694d9da5526e6255bb73c3

#include <stdio.h>
#include <stdlib.h>
struct Sentense
{
    char **words;
    char * str;
    unsigned short length;
    int top;
    int strCount;
};
int main() {
    struct Sentense sentense;
    sentense.top=-1;
    sentense.strCount=0;
    sentense.length=100;
    sentense.words=(char **)malloc(sentense.length*sizeof(char *));
    sentense.str = (char*)malloc(1000*sizeof(char));

    
    while(1)
    {
        char c=getchar();
        static unsigned short wordCount=0;        
        if(c!=' '&&c!='\n')
        {
            wordCount++;
            sentense.str[sentense.strCount++]=c;
        }
        else
        {
            wordCount++;
            sentense.str[sentense.strCount++]='\0';
            //如果堆栈不够大,拓展堆栈
            if(sentense.top>=sentense.length-1){
                sentense.length+=100;
                sentense.words = (char **)realloc(sentense.words, sentense.length*sizeof(char *));
            }
            sentense.words[++sentense.top]=sentense.str+sentense.strCount-wordCount;
            wordCount = 0;
            if(c=='\n')
                break;
        } 
    }
    while(sentense.top>=0)
    {
        printf("%s ",sentense.words[sentense.top--]);
    }
    return 0;
}

全部评论

相关推荐

05-29 22:11
门头沟学院 Java
Elastic90:抛开学历造假不谈,这公司的招聘需求也挺怪的,Java开发还要求你有图文识别、移动端开发和c++的经验,有点逆天了。
点赞 评论 收藏
分享
认真搞学习:28小登的建议,投算法岗不要写什么物理竞赛,互联网+,多写点项目,用什么算法做了什么。还有本科算法是不可能的开发你这个也没有项目啊
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务