一道C语言题,自己写的代码

#include<stdio.h>boolpeiqian(int,int);boolzhuanqian(int,int);boolzhuan(int,int,int,in... #include<stdio.h>
bool peiqian(int ,int);
bool zhuanqian(int ,int);
bool zhuan(int ,int ,int ,int);
bool is_nineorsix(int *p);
bool except(int );
int convert(int);
int main(void)
{
int shu1,shu2;
int xshu1,xshu2;
for(xshu1 = 1001;xshu1<10000;xshu1++)
{
if(except(xshu1))
{
shu1=convert(xshu1);
if(peiqian(xshu1,shu1))
for(xshu2 = 1001;xshu2<10000;xshu2++)
{
if(except(xshu2))
{
shu2=convert(xshu2);
if(zhuanqian(xshu2,shu2))
if(zhuan(shu1,shu2,xshu1,xshu2))
printf("%d ",xshu1);
}
}
}
}
return 0;
}
bool is_nineorsix(int *p)
{
if(*p == 6)
*p = 9;
else if(*p == 9)
*p = 6;
return true;
}
bool zhuanqian(int xshu,int shu)
{
if(xshu-shu>800&&xshu-shu<900)
return true;
else
return false;
}
bool peiqian(int xshu,int shu)
{
if((xshu-shu<-200)&&(xshu-shu>-300))
return true;
else
return false;
}
bool zhuan(int shu1,int shu2,int xshu1,int xshu2)
{
if((shu1+shu2-xshu1-xshu2) == 558)
return true;
else
return false;
}
bool except(int shu)
{
int ge,shi,bai,qian;
ge = shu%10;
shi = shu%100/10;
bai = shu%1000/100;
qian = shu/1000;
if(ge==1 || ge==2 || ge==5 || ge==6 || ge==9)
{
if(shi==0||shi==1||shi==2||shi==5||shi==6||shi==8||shi==9)
{
if(bai==0||bai==1||bai==2||bai==5||bai==6||bai==8||bai==9)
{
if(qian==0||qian==1||qian==2||qian==5||qian==6||qian==8||qian==9)
return true;
else
return false;
}
else
return false;
}
else
return false;
}
else
return false;
}
int convert(int xshu)
{
int shu;
int ge,shi,bai,qian;
ge = xshu%10;
shi = xshu%100/10;
bai = xshu%1000/100;
qian = xshu/1000;
is_nineorsix(&ge);
is_nineorsix(&shi);
is_nineorsix(&bai);
is_nineorsix(&qian);
shu = ge*1000+shi*100+bai*10+qian;
return shu;
}
/*
小李的店里专卖其它店中下架的样品电视机,可称为:样品电视专卖店。
其标价都是4位数字(即千元不等)。
小李为了标价清晰、方便,使用了预制的类似数码管的标价签,只要用颜色笔涂数字就可以了(参见p1.jpg)。
这种价牌有个特点,对一些数字,倒过来看也是合理的数字。如:1 2 5 6 8 9 0 都可以。这样一来,如果牌子挂倒了,有可能完全变成了另一个价格,比如:1958 倒着挂就是:8561,差了几千元啊!!
当然,多数情况不能倒读,比如,1110 就不能倒过来,因为0不能作为开始数字。
有一天,悲剧终于发生了。某个店员不小心把店里的某两个价格牌给挂倒了。并且这两个价格牌的电视机都卖出去了!
庆幸的是价格出入不大,其中一个价牌赔了2百多,另一个价牌却赚了8百多,综合起来,反而多赚了558元。
请根据这些信息计算:赔钱的那个价牌正确的价格应该是多少?
*/
求解释哪里需要改,编译后打印不出想要的结果
展开
 我来答
时欢悦0BF
推荐于2016-05-20 · TA获得超过609个赞
知道小有建树答主
回答量:624
采纳率:0%
帮助的人:729万
展开全部
#include<stdio.h>
bool peiqian(int ,int);
bool zhuanqian(int ,int);
bool zhuan(int ,int ,int ,int);
bool is_nineorsix(int *p);
bool except(int );
int convert(int);
int main(void)
{
 int shu1,shu2;
 int xshu1,xshu2;
 for(xshu1 = 1001;xshu1<10000;xshu1++)
 {
  if(except(xshu1))
  {   
   shu1=convert(xshu1);
   if(peiqian(xshu1,shu1))
    for(xshu2 = 1001;xshu2<10000;xshu2++)
     {   
      if(except(xshu2))
      {   
       shu2=convert(xshu2);
       if(zhuanqian(xshu2,shu2)) {
        if(zhuan(shu1,shu2,xshu1,xshu2))
         printf("%d  ",xshu1);
         }   
      }   
     }   
  }
 }
 return 0;
}
bool is_nineorsix(int *p) 
{
 if(*p == 6)  
  *p = 9;
 else if(*p == 9)
  *p = 6;
 return true;
}
bool zhuanqian(int xshu,int shu)
{
// 赚钱应该是 错价-原价大于800小于900
 if(shu-xshu>800&&shu-xshu<900)
  return true;
 else 
  return false;
}
bool peiqian(int xshu,int shu)
{
// 赔钱应该是 原价-错价大于200且小于300 
 if((xshu-shu > 200)&&(xshu-shu < 300))
  return true;
 else
  return false;
}
bool zhuan(int shu1,int shu2,int xshu1,int xshu2)
{
 if((shu1+shu2-xshu1-xshu2) == 558)
  return true;
 else
  return false;
}
bool except(int shu)
{
 int ge,shi,bai,qian;
 ge = shu%10;
 shi = shu%100/10;
 bai = shu%1000/100;
 qian = shu/1000;
 // 这里忽略了ge == 8
 if(ge==1 || ge==2 || ge==5 || ge==6 || ge == 8 || ge==9)
 {
  if(shi==0||shi==1||shi==2||shi==5||shi==6||shi==8||shi==9)
  {
   if(bai==0||bai==1||bai==2||bai==5||bai==6||bai==8||bai==9)
   {
    if(qian==0||qian==1||qian==2||qian==5||qian==6||qian==8||qian==9)
     return true;
    else
     return false;
   }
   else
    return false;
  }
  else
   return false;
 }
 else
  return false;
}
int convert(int xshu)
{
 int shu;
 int ge,shi,bai,qian;
 ge = xshu%10;
 shi = xshu%100/10;
 bai = xshu%1000/100;
 qian = xshu/1000;
 is_nineorsix(&ge);
 is_nineorsix(&shi);
 is_nineorsix(&bai);
 is_nineorsix(&qian);
 shu = ge*1000+shi*100+bai*10+qian;
 return shu;
}
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式