[英]Palindrome Checker
我得到了以下任务:
编写一个以字符串作为输入的程序,并打印字符串的最长前缀,该字符串的反向是字符串的有效后缀。 例如,如果给出“符号”作为输入,则前缀“否”是在末尾具有匹配的有效后缀(即“开”)的最长前缀。
如果字符串是回文(即如果字符串与其反向相同),则前缀是整个字符串本身。 例如,如果输入是“civic”,那么最长的前缀本身就是“civic”。 如果字符串没有有效的前缀,则打印0.例如,如果输入字符串是“bird”,则第一个字符本身不匹配,并且没有有效的前缀。
字符串中的符号仅来自集合{AZ,az}。 符号区分大小写。 即'A'和'a'被认为是不同的。 您将获得一个名为printChars()的函数,该函数将从p指向的起始位置到q指向的结束位置打印一个字符数组。 如果p为NULL,则输出0。
该函数的原型是:
void printChars(char *p, char *q);
您不必为printChars()函数编写程序。 此函数会自动添加到您编写的代码段的末尾。
如果您愿意,可以在库中使用字符串函数。
INPUT:输入是一个长度为N的字符串,仅由来自集合{A-Za,z}的符号组成。
OUTPUT:具有相应匹配后缀的最长前缀,如果不存在此前缀,则为0。
约束:输入将满足以下属性。 没有必要验证输入。
1 <= N <= 99
我编写了代码,但编译失败了。 可能导致问题的原因是什么?如何解决?
#include<stdio.h>
#include<string.h>
void printChars(char *p,char *q);
int main()
{
char a[99];
int n;
scanf("%s",a);
char *p=null,*q=null,*x;
p=&a[0];
q=&a[0];
n=strlen(a);
x=&a[0]+(n-1);
for(int i=0;i<=(n-1);i++)
{
if(*x==*q)
{
x--;
q++;
}
else
{
q--;
break;
}
}
x=&a[0]+(n-1);
if(*p!=*x)
printf("0");
printchars(p,q);
return 0;
}
void printChars(char *p, char *q)
{
if (p==NULL){
printf("0");
}
else{
while(p <= q){
printf("%c",*p);
p++;
}
}
仍然出错
Program:52:1: warning: data definition has no type or storage class [enabled by default]
Program:52:1: warning: type defaults to 'int' in declaration of 'printChars' [enabled by default]
Program:52:1: warning: parameter names (without types) in function declaration [enabled by default]
Program:52:1: error: conflicting types for 'printChars'
Program:34:6: note: previous definition of 'printChars' was here
Program:54:1: error: expected identifier or '(' before 'return'
Program:56:1: error: expected identifier or '(' before '}' token
Program:59:6: error: redefinition of 'printChars'
Program:34:6: note: previous definition of 'printChars' was here
在C中没有名为null
预定义宏。
更改
char *p=null,*q=null,*x;
至
char *p = NULL, *q = NULL, *x;
更改功能调用
printchars(p,q);
^ This 'c' should be in capital
至
printChars(p,q);
你还错过了printChars
函数的结束括号}
。
最后你的运行代码: http : //ideone.com/SczMu2
试试这个代码
#include<stdio.h>
#include<string.h>
void printChars(char *p,char *q);//function prototype
int main()
{
int i,n,k=0,j;
char a[100];
char b[100];
char *p;
char *q;
printf("enter array of chars");
scanf("%s",a);
n=strlen(a);
j=n;
for(i=0;i<n;i++)
{
b[j-1]=a[i];
j--;
}
for(i=0;i<n;i++)
{
if(a[i]==b[i])
{k++;
p=a;}
//printf("%c",a[i]);
else if(a[i]!=b[i]&&k==0){
p=NULL;break;}
else break;
}
//p=a;
q=&a[k-1];
printChars(p,q);
return 0;
}//end of main
void printChars(char *p, char *q)
{
if (p==NULL){
printf("0");
}
else{
while(p <= q){
printf("%c",*p);
p++;
}
}
}
大约一年前,我接近了类似的任务。
看看这个功能。 它返回从单词中打印多少个字符的数量。
int palindromeWordIndex(char *str)
{
int indexLeft = 0, indexRight = strlen(str)-1;
while (indexLeft <= indexRight)
{
if (str[indexLeft] == str[indexRight]){
indexLeft++;
indexRight--;
}
else
return indexLeft;
}
return strlen(str);
}
我从我自己的函数中重新编写了它,只检查一个单词是否是回文。
int isPalindromeIter(char *str){
int indexLeft = 0, indexRight = strlen(str)-1;
while (indexLeft <= indexRight){
if (str[indexLeft] == str[indexRight]){
indexLeft++;
indexRight--;
}
else
return 0;
}
return 1;
}
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.