前两天看到一道题,题目是这样说的:
题目描述
小艺定义一个幸运数字的标准包含3条: 1、仅包含4或7。 2、幸运数字的前半部分数字等于后半部分数字。 3、数字的长度是偶数。
由于本人是初学,所以只能用c语言代码解答:
在看这道题的时候,由于要输入的数组不知道具体长度,所以我们定义一个字符型的数组,用 strlen 函数来确定他的长度len,对长度进行对2求余,第三个问题解决。
再看第二个问题,我们可以再定义一个字符型数组,用倒叙的方法赋值,再一对一地比较,具体操作如下:
![](https://i-blog.csdnimg.cn/blog_migrate/371a2d3d5d148b57d29f7cd69b3d91be.png)
当然,前面数组的名字自己定义,循环变量也要定义,再循环len 遍,一一比对;
最后一个问题,仅包含4或7,这里我们可以用定义宏常量的方法:
![](https://i-blog.csdnimg.cn/blog_migrate/1cc1af6debe6dbad827e816b3ead02ae.png)
一定注意,在比对时,4或7是单个字符,要用’‘把它括起来;
再用一个变量flag 来确定结果。
最后是完整代码:
#include <stdio.h>
#include <stdlib.h>
#define four '4'
#define seven '7'
void solution(char n[],int len)
{
char arr[1000];
int i,j,k,flag=0;
if(len%2==0)
{
for(i=0,j=len-1;i<len,j>=0;i++, j--)
{
arr[i]=n[j];
}
for(k=0;k<len;k++)
{
if(arr[k]==n[k])
{
if(n[k]==four||n[k]==seven)
{
flag =1;
}
}
}
}
if(flag==1)
printf("Yes");
else
printf("No");
}
int main()
{
char n[1000];
scanf("%s",&n);
int len =strlen(n);
solution(n,len);
return 0;
}