题解 | #句子逆序#

句子逆序

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;
}

全部评论

相关推荐

07-03 16:02
门头沟学院 Java
今天面试,非常紧张,面试官问我springboot有哪些核心模块都答不上来了,真的对自己无语了!
程序员小白条:28届我勒个去,很多人面试都没机会
查看1道真题和解析
点赞 评论 收藏
分享
点赞 评论 收藏
分享
06-14 19:09
门头沟学院 Java
darius_:给制造业搞的,什么物料管理生产管理,设备管理点检,最最关键的就是一堆报表看板。个人觉得没啥技术含量都是些基本的crud,但是业务很繁琐那种
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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