问题描述:
小李的店里专卖其它店中下架的样品电视机,可称为:样品电视专卖店。其标价都是4位数字(即千元不等)。小李为了标价清晰、方便,使用了预制的类似数码管的标价签,只要用颜色笔涂数字就可以了。
这种价牌有个特点,对一些数字,倒过来看也是合理的数字。如:1 2 5 6 8 9 0 都可以。这样一来,如果牌子挂倒了,有可能完全变成了另一个价格,比如:1958 倒着挂就是:8561,差了几千元啊!!
当然,多数情况不能倒读,比如,1110 就不能倒过来,因为0不能作为开始数字。有一天,悲剧终于发生了。某个店员不小心把店里的某两个价格牌给挂倒了。并且这两个价格牌的电视机都卖出去了!
庆幸的是价格出入不大,其中一个价牌赔了2百多,另一个价牌却赚了8百多,综合起来,反而多赚了558元。
请根据这些信息计算:赔钱的那个价牌正确的价格应该是多少?
答案是一个4位的整数,请通过浏览器直接提交该数字。
#include<stdio.h>
#define n 4
int firstprice; //原价
int endprice; //颠倒后的价格
int swap(int m) //判断是否能倒读,如果能倒读则交换,并返回1,否则返回0
{
int a[n];
int temp;
int i=0;
temp=m;
endprice=0;
if(temp%10==0) //如果最后一位为0,这种情况不能倒读
return 0;
while(temp)
{
if(temp%10==3||temp%10==4||temp%10==7)
return 0;
else
a[i++]=temp%10;
temp/=10;
}
for(int j=0;j<n;j++)
{
if(a[j]==9)
a[j]=6;
else if(a[j]==6)
a[j]=9;
endprice=endprice*10+a[j];
}
return 1; //交换成功 返回1
}
int main()
{
int num,temp;
int x,y,i,j,k;
int a1[100],a2[100],b1[100],b2[100];
x=0;
y=0;
for(num=1001;num<=9999;num++)
{
if(swap(num)) //交换成功
{
// printf("############%d %d\n",num,endprice);
firstprice=num; //最初的价格
if(firstprice-endprice>200 && firstprice-endprice<300) //赔钱
{
a1[x]=firstprice;
a2[x]=endprice;
// printf("%d %d****************\n",a1[x],a2[x]);
x++;
}
if(endprice-firstprice>800 && endprice-firstprice<900) //赚钱
{
b1[y]=firstprice;
b2[y]=endprice;
// printf("%d %d&&&&&&&&&&&&&&&&&&&\n",b1[y],b2[y]);
y++;
}
}
}
// printf("%d %d\n",x,y);
for(i=0;i<x;i++)
{
for(j=0;j<y;j++)
{
if((b2[j]-b1[j])-(a1[i]-a2[i])==558)
printf("赔钱的原价:%d 赔钱的现价:%d\n",a1[i],a2[i]);
}
}
return 0;
}