2016-04-04 143 views
1

我有一个比较简单的问题。用户应该运行该程序,输入30个字符或更少的消息,然后单个字母的情况将被切换(小写字母将被制成upercase,反之亦然)。除了改变案件的部分,一切都很好。我应该使用指向数组中的char的指针,并将其作为函数参数传递给toggle_case。请协助我如何实现这一点。 这是代码。传递数组元素指针c

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

void read_message(char *message, int *message_size); 
void toggle_case(char *character); 
void count_cv(char* message); 

int main() { 

    char message[30]; 
    int message_size; 

    char *message_pointer; 
    message_pointer = message; 

    read_message(message, &message_size); 
    int i = 0; 
    for(i =0; i<30; i++){ 
     toggle_case(&message_pointer[i]); 
    } 
    printf("New string: %s",message); 
    return 0; 
} 

void read_message(char *message, int *message_size){ 
    printf("Enter your string (maximum 30 characters): "); 
    fgets(message, 30, stdin); 
} 

void toggle_case(char *character){ 
    //check if character is a letter 
    if (isalpha(*character)) { 
    //Check if the character is upper case 
    if(isupper(*character)){ 
     //convert the character to lower case 
     tolower(*character); 
    } else { 
     //Check if the character is lower case 
     //convert the character to upper case 
     toupper(*character); 
    } 
} 
} 

void count_cv(char* message){ 

} 
+0

你的难度到底是什么?代码是否不编译,是否崩溃,是否产生错误的输出等?向我们解释清楚,以便我们知道该怎么帮助你。它看起来好像不会将结果保存到'toggle_case'中的原始字符中。如果这是您的问题,那么可以在'toggle_case'内分配结果或返回结果供调用者分配。 – kaylum

+0

'message_size'似乎并没有被使用...... – dreamlax

回答

1

tolowertoupper返回的新特性,你需要指定它回到您更新的位置。

if (isupper(*character)) { 
    *character = tolower(*character); 
} else { 
    *character = toupper(*character); 
} 

顺便说一句,你不需要先检查字符是否是字母。如果它不是字母,则tolowertoupper将简单地返回该字符。

+0

感谢哥们,这样一个愚蠢的错误。 –