poj 1013 Counterfeit Dollar(模拟)

恩,以前做过的一个智力题,本以为可以很简单解决,没想到却拖了好几天也没解决,总的来说是没理清思路,没想好怎么保存已经确定的状态,最后才考了一下网上代码才解决,其实开两个数组就行了,只是当时没想到,总是想着能少开个数组就少开个,节约空间,但是这样会浪费时间,其实结果是一样。

代码:

#include <stdio.h>
#include <stdlib.h>
#include <string.h>

int w[20];//存储现态;
int f[20];//存储上一个状态

int main()
{
    int len,cas,i,j;
    char left[20],right[20],res[10];

    scanf("%d",&cas);
    getchar();
    while(cas--)
    {
        memset(w,-1,sizeof(w));
        for(j=1;j<=3;j++)
        {
            scanf("%s%s%s",left,right,res);
            getchar();
            len=strlen(left);
            memset(f,0,sizeof(f));
            if (strcmp(res,"even")==0)//两边相等时,每一个硬币都是真的。
            {
                for(i=0;i<len;i++)
                w[left[i]-'A']=w[right[i]-'A']=0;
            }
            else if(strcmp(res,"up")==0)//up时,左边重右边轻
            {
                memcpy(f,w,sizeof(w));
                memset(w,0,sizeof(w));
                for(i=0;i<len;i++)
                {
                    w[left[i]-'A']=2;
                    w[right[i]-'A']=1;
                }
                for(i=0;i<16;i++)
                if(f[i]>=0 && w[i] != f[i])
                w[i]=0;
            }
            else//down时左边轻右边重
            {
                memcpy(f,w,sizeof(w));
                memset(w,0,sizeof(w));
                for(i=0;i<len;i++)
                {
                    w[left[i]-'A']=1;
                    w[right[i]-'A']=2;
                }
                for(i=0;i<16;i++)
                if(f[i]>=0 && w[i] != f[i])
                w[i]=0;
            }
        }
        for(i=0;i<16;i++)
        if(w[i]>0)
        printf("%c is the counterfeit coin and it is %s.\n",i+'A',w[i]==1?"light":"heavy");
    }
    return 0;
}

转载于:https://www.cnblogs.com/misty1/archive/2012/05/04/2482208.html

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值