sinat_23707495 2014-11-21 17:45 采纳率: 0%
浏览 1705

新人Counterfeit Dollar三次称假币问题

fzuacm1003 Counterfeit Dollar问题
根据逻辑推理进行判断,并且已经排除真币在相同情况两端都出现的特例(不知是否正确- -)
提交总是wa。。。跪求帮忙改正。。。

  • 写回答

1条回答

  • sinat_23707495 2014-11-21 17:45
    关注

    代码的描述
    #include
    #include
    void even(char *n1,char *n2,int *n);
    void up(char *n1,char *n2,int *n);
    void down(char *n1,char *n2,int *n);
    void judge(int *n);
    int main()
    {
    int coins[12]={0};//赋值为0,表示情况不明,1表示真币,10轻假币,11重假币
    char cases[3][7];
    int follow,i,j,k;
    scanf("%d",&follow);
    for(i=0;i<follow;++i)
    {
    for(j=0;j<3;++j)
    {
    for(k=0;k<3;++k)
    {
    scanf("%s",&cases[k]);
    }
    if(strcmp(cases[2],"even")==0)//天平相等
    {
    even(cases[0],cases[1],coins);
    }
    else if(strcmp(cases[2],"up")==0)//左重右轻
    {
    up(cases[0],cases[1],coins);
    }
    else if(strcmp(cases[2],"down")==0)//右重左轻
    {
    down(cases[0],cases[1],coins);
    }
    }
    }
    judge(coins);
    }

    void even(char n1,char *n2,int *n)//平衡情况下的处理
    {
    char c;
    int i;
    for(i=0;i<12;++i)
    {
    c=(char)65+i;
    if((strchr(n1,c))!=NULL||(strchr(n2,c))!=NULL)// 如果出现即真币
    {
    *(n+i)=1;
    }
    }
    }
    void up(char *n1,char *n2,int *n)
    {
    char c;
    int i;
    for(i=0;i<12;++i)
    {
    c=(char)65+i;
    if((strchr(n1,c))!=NULL&&(
    (n+i))==0)//情况不明且在重的一端
    {
    (n+i)=11;
    }
    else if((strchr(n2,c))!=NULL&&(
    (n+i))==0)//情况不明且在轻的一端
    {
    (n+i)=10;
    }
    else if((strchr(n1,c))!=NULL&&(
    (n+i))==10)//曾在轻的一端处出现并处于重的一端,为真币
    {
    (n+i)=1;
    }
    else if((strchr(n2,c))!=NULL&&(
    (n+i))==11)//曾在重的一端处出现并处于轻的一端,为真币
    {
    *(n+i)=1;
    }
    else if(((strchr(n1,c))==NULL)&&((strchr(n2,c))==NULL))//未参加比较,为真币
    {
    *(n+i)=1;
    }
    }
    }

    void down(char n1,char *n2,int *n)
    {
    char c;
    int i;
    for(i=0;i<12;++i)
    {
    c=(char)65+i;
    if((strchr(n1,c))!=NULL&&(
    (n+i)==0))//情况不明且在轻的一端
    {
    (n+i)=10;
    }
    else if((strchr(n2,c))!=NULL&&(
    (n+i))==0)//情况不明且在重的一端
    {
    (n+i)=11;
    }
    else if((strchr(n1,c))!=NULL&&(
    (n+i))==11)//曾在重的一端处出现并处于轻的一端,为真币
    {
    (n+i)=1;
    }
    else if((strchr(n2,c))!=NULL&&(
    (n+i))==10)//曾在轻的一端处出现并处于重的一端,为真币
    {
    (n+i)=1;
    }
    else if(((strchr(n1,c))==NULL)&&((strchr(n2,c))==NULL))//未参加比较,为真币
    {
    *(n+i)=1;
    }
    }
    }
    void judge(int *n)
    {
    char c;
    for(int i=0;i<12;++i)
    {
    if(
    (n+i)!=1)
    {
    if(*(n+i)==10)
    {
    c=(char)65+i;
    printf("%c is the counterfeit coin and it is light.",c);
    }
    else if(*(n+i)==11)
    {
    c=(char)65+i;
    printf("%c is the counterfeit coin and it is heavy.",c);
    }
    }
    }
    }

    评论

报告相同问题?

悬赏问题

  • ¥15 求差集那个函数有问题,有无佬可以解决
  • ¥15 【提问】基于Invest的水源涵养
  • ¥20 微信网友居然可以通过vx号找到我绑的手机号
  • ¥15 寻一个支付宝扫码远程授权登录的软件助手app
  • ¥15 解riccati方程组
  • ¥15 display:none;样式在嵌套结构中的已设置了display样式的元素上不起作用?
  • ¥15 使用rabbitMQ 消息队列作为url源进行多线程爬取时,总有几个url没有处理的问题。
  • ¥15 Ubuntu在安装序列比对软件STAR时出现报错如何解决
  • ¥50 树莓派安卓APK系统签名
  • ¥65 汇编语言除法溢出问题