-1

出于某种原因,我无法让它工作!谁能告诉我哪里出错了?这应该反转给定字符串中的单词(即从“this is a test”到“test a is this”)

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

char *reverse(char const *input)
{
    char *ret = (char *)malloc(sizeof(char) * strlen(input));
    int length = 0;
    int numWords = 1;
    int i;
    for(i=0; input[i]!=NULL; i++)
    {
        length++;
        if(input[i]==' ')
            numWords++; 
    }
    char words[numWords];
    int currentWord = numWords;
    for(i=0; input[i]!=NULL; i++)
    {
        if (input[i]==' '){
            currentWord--;
        }else{
            words[currentWord] = words[currentWord] + input[i];
        }
    }
    for(i=0; i < numWords; i++)
    {
        ret = ret + words[i];
    }

    return ret;
}

int main(int argc, char **argv)
{
    int nTestcase = 0;
    int i = 0;
    char inputstr[100];
    char *reversedStr = NULL;
    scanf("%d\n", &nTestcase);
    for (i = 0; i < nTestcase; i++)
    {
        fgets(inputstr, 100, stdin);
        reversedStr = reverse(inputstr);
        printf("%s\n", reversedStr);
        free(reversedStr);
        memset(inputstr, 0, 100);
    }
    return 0;
}
4

3 回答 3

1
words[currentWord] = words[currentWord] + input[i];

您不能像期望字符串连接那样相互添加字符。我想你希望words是一个单词数组(即字符串),但它的类型不是那个,words只是一个字符数组。

就像@Tom 说的那样,你在最后一个 for 循环中再次这样做:

ret = ret + words[i];
于 2013-02-16T04:43:42.980 回答
0

Joseph,与其他编程语言(c# 或 PHP)不同,C 的字符串处理功能非常基本。

您不能直接添加字符串,但是可以使用许多库函数来完成相同的任务。

查看,

  • strtok - 使用它将字符串拆分为单词。strtok 参考

  • strncat - 用于连接字符串

C 中的字符串只是以空字符(值为 0 的字节)结尾的字节数组。

于 2013-02-16T06:18:13.923 回答
0

这是更短/更清洁的方式

private char[] reverseWords(char[] words) {

    int j = words.length - 1;

    for (int i = 0; i < (words.length)/2; i++) {
        if(i==j)
            continue;

        char temp = words[i];
        words[i] = words[j];
        words[j]=temp;
        j--;
    }
    int lastIndex = 0;
    for (int i=0;i<words.length;i++){
        if(words[i]==' '){
            words = reverseWord(words,lastIndex,i-1);
            lastIndex=i+1;
        }
    }
    words = reverseWord(words,lastIndex,words.length-1);

    return words;
}

private char[] reverseWord(char[] words, int from, int to) {
    int j=to;
    for(int i=from;i<((to/2)+from/2);i++){
        if(i==j) continue;

        char temp = words[j];
        words[j]=words[i];
        words[i]=temp;
        j--;
    }
    return words;
}
于 2018-09-20T10:25:19.943 回答