题解 | #单词倒排#

单词倒排

https://www.nowcoder.com/practice/81544a4989df4109b33c2d65037c5836

#include <stdio.h>
#include <stdlib.h>
#include <string.h>

void reverse(char* start, char* end){       //用于反转整个字符串
    char tmp;
    while(start < end){
        tmp = *start;
        *start = *end;
        *end = tmp;
        start++, end--;
    }
}
//用于将end-start的字符,逐个赋值给dst,并更新dstLen
void copyReverseToDst(char* start, char* end, char* dst, int* dstlen){
    while(end >= start){
        *dst++ = *end--;
        (*dstlen)++;
    }
}

int main() {
    char input[10001];
    char* ret = (char*)malloc(sizeof(char)*10001);      //为返回值申请空间
    int retLen = 0;
    int len, start, end;
    gets(input);
    len = strlen(input);
    reverse(&input[0], &input[len-1]);  //翻转整个字符串
    start = end = 0;    
    while(1){
        while((input[end]>='a'&&input[end]<='z') || (input[end]>='A'&&input[end]<='Z'))end++;   //找到完整单词的下一位
        copyReverseToDst(&input[start], &input[end-1], &ret[retLen], &retLen);  //将该单词反转赋值到dst,注意end-1,因此此时end指向的是单词的下一位,即结束符
        ret[retLen++] = ' ';    //间隔
        while(end < len && !((input[end]>='a'&&input[end]<='z') || (input[end]>='A'&&input[end]<='Z')))end++;   //找到下一个单词的起始,虽然这里用end来移动,但是end会赋值给start
        if(end >= len)break;    //如果end超过最大输入长度,则表示倒排结束
        start = end;
    }
    ret[retLen] = '\0'; //结束符
    printf("%s", ret);
    free(ret);
    return 0;
}

全部评论

相关推荐

来个大佬救一下,为上投了都是石沉大海了,没实习经历的话怕秋招直接进不了面。什么实习这么难找,基本
心态爆炸了:现在正式的岗位都少,实习基本不咋招的,除了大厂,中小企业其实没那么多岗位需求,就算是有,大多都是招一两个廉价劳动力,同时,他们也会希望你一来就能干活的,没时间培训你,就让你了解公司的项目,你了解完就可以开始干活。再者是,很多低质量的实习其实用处没有那么大的。我去年也是找实习找到破防,最后去了一家深圳的小公司实习,工作对我来说很简单,甚至不如我在学校做的项目,秋招的时候,这段实习经历也并没有帮上什么忙,投递简历,依旧非常低的回复率。低回复率是常态,尤其是找实习,找不到,那就把重心放在优化自己的简历和项目,多看八股文,锻炼自己的面试能力,多看别人的面经,自己模拟面试,等秋招的时候,只要有那么寥寥几次,好好抓住那几次机会。
点赞 评论 收藏
分享
流浪的神仙:无恶意,算法一般好像都得9硕才能干算法太卷啦
点赞 评论 收藏
分享
评论
1
收藏
分享

创作者周榜

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