我有一个argv c程序,它会反转这个单词,看看它是不是一个回文。我只是想清理输出并让它打印原始输入而不是反转输入,但由于它是argv,我似乎无法弄清楚如何做到这一点。
int main(int argc,char * argv [])
{
char string =(char )malloc(1000);
string [0] =' \ 0&#39 ;;
for(i = 1; i < argc; i++)
strcat(string, argv[i]);
for(j = 0; string[ j ]; j++)
string[j] = tolower(string[ j ]);
reverse(string);
printf("Reverse of entered word is \"%s\".\n", string);
result = is_palindrome(string);
if ( result == 1)
printf("\"%s\" is a palindrome.\n", string);
else
printf("\"%s\" is not a palindrome.\n", string);
system("pause");
}
我遗漏了其余的功能,但你可以在主要内容中看到printf显示它是不是或不是回文。不知道如何使其等于原始输入,并知道参数的数量。目前它打印反转的字符串,当我认为打印原件会更好看。我觉得我太难了,但我不确定。
答案 0 :(得分:0)
显而易见的方法是反转反向字符串,另一种方法是使用双引号将单个参数/字符串传递给程序:
./program "a man a plan a canal panama"
而不是
./program a man a plan a canal panama
然后你不需要遍历args。
答案 1 :(得分:0)
更新,因为OP说教授会输入句子(没有引号!)。
这可以简单地使用MSVC库函数完成。因为strdup
分配了内存,所以也需要清理。
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
void fatal(char *msg);
int main(int argc, char *argv[]) {
int i, argslen = 0;
char *inp, *rev;
if (argc < 2) // check num args
fatal("Need a string argument");
for (i=1; i<argc; i++) // figure input length
argslen += strlen(argv[i]) + 1; // include spaces and EOS
inp = malloc(argslen); // memory for concatenation
if (inp == NULL)
fatal("Memory allocation error");
strcpy(inp, argv[1]); // prime with first arg
for (i=2; i<argc; i++) { // concat other args
strcat(inp, " ");
strcat(inp, argv[i]);
}
rev = strdup(inp); // make a copy
if (rev == NULL)
fatal("Memory allocation error");
strrev(rev); // reverse the copy
printf("Testing: \"%s\"\n", inp);
if (stricmp(inp, rev) == 0) // case insensitive test
printf("Is a palindrome\n");
else
printf("Not a palindrome\n");
free (inp); // release mine
free (rev); // release library's
return 0;
}
void fatal(char *msg) {
printf("%s\n", msg);
exit (1);
}
计划结果:
>test Able was I ere I saw Elba
Testing: "Able was I ere I saw Elba"
Is a palindrome
答案 2 :(得分:0)
我看到两个问题:
参数数量在argc
中 - 参见例如有关argc
和argv[]
的详细信息,请this question。
关于如何打印原始字符串,您可以在调用reverse()
之前打印字符串,将原始字符串存储在临时变量中以便稍后输出或在打印之前再次反向输出。第三种选择如下:
int main(int argc, char* argv[])
{
char *string = (char*)malloc(1000);
string[0] = '\0';
for(i = 1; i < argc; i++)
strcat(string, argv[i]);
for(j = 0; string[ j ]; j++)
string[j] = tolower(string[ j ]);
reverse(string);
printf("Reverse of entered word is \"%s\".\n", string);
result = is_palindrome(string);
if ( result == 1)
printf("\"%s\" is a palindrome.\n", reverse(string));
else
printf("\"%s\" is not a palindrome.\n", reverse(string));
system("pause");
}