一辆以固定速度行驶的汽车,司机在上午10点看到里程表(里程表有6位)上的读数是一个对称数95859(即这个数从左向右读和从右向左读是完全一样的)。两小时后里程表上出现了一个新的对称数。问该车的速度是多少?新的对称数是多少?
#include"stdio.h"
int main(){
int a[5];
int i;
int j;
int t;
for(i = 95860 ; ; i++)
{
j = i;
for(t = 0; j != 0; t++)
{
a[t] = j % 10;
j /= 10;
}
if((a[0] == a[4]) && (a[1] == a[3]))
{
printf("the new symmetrical number kelometers is:%d%d%d%d%d\n",a[4],a[3],a[2],a[1],a[0]);
printf("the velocity of the car is:%.2f\n",(i - 95859)/2.0);
break;
}
}
return 0;
}
如果给定一个已知位数的数:i = 1234,要求将它的每一位数分离开来 a,b,c,d分别是它的千百十个位
{
a = i / 1000 ;
b = i % 1000 / 100 ;
c = i % 100 / 3 ;
d = i % 10 ;
}
可以轻松分离开
可给定一个不知位数的数,要求将它的每一位分离开如果用上述方法就会变得很复杂,这时候就要用到一个小技巧
给定一个数i ,要求将它的每一位数分离开来,部分程序如下:
int a[];
int i;
int t;
for(t = 0;i != 0;t++)
{
a[t] = i % 10;
i = i / 10;
}
这样就可以把这个数的每一位分开并存放在数组中。
思考题:求小于1993的最大的数的二进制对称数。
#include <stdio.h>
#include <stdlib.h> //程序中用到itoa函数
#include <string.h>
int main()
{
char a[128];
char b[128];
int i;
for(i = 1; i <= 1993; i++)
{
itoa(i,a,2); //把i变成二进制存储在数组a中
strcpy(a,b); //把数组a复制到数组b
strrev(b); //把数组b倒序排列
if(!strcmp(a,b))
{
printf("%d\n",i);
}
}
return 0;
}
运行结果:1967
如有错误,欢迎指正。。。