首页 > 其他 > 详细

poj1029(找假硬币)模拟

时间:2014-05-10 10:38:53      阅读:800      评论:0      收藏:0      [点我收藏+]

题意:给n个硬币,其中有一个硬币和其他的硬币重量不一样,给出k次比较重量的结果。问是否可以将假硬币找出来。


解法:判断一个硬币是真币的方法(满足其一):

         1、这个硬币出现过在=的两边 

         2、既出现在小于的一边过,也出现在大于的一边过。

        如果排除这些硬币后只剩下一个,那么假币就是剩下的那个,否则就是不确定。

代码:

/****************************************************
* author:xiefubao
*******************************************************/
#pragma comment(linker, "/STACK:102400000,102400000")
#include <iostream>
#include <cstring>
#include <cstdlib>
#include <cstdio>
#include <queue>
#include <vector>
#include <algorithm>
#include <cmath>
#include <map>
#include <set>
#include <stack>
#include <string.h>

using namespace std;

#define eps 1e-8
typedef long long LL;




int n,k;
int num[1010];
int rem[1010];
vector<int> vec1;
vector<int> vec2;
int main()
{
    while(scanf("%d%d",&n,&k)==2)
    {
        memset(num,0,sizeof num);
        memset(rem,0,sizeof rem);
        int sum=0;
        int ans=0;
        for(int i=0; i<k; i++)
        {
            int m;
            vec1.clear();
            vec2.clear();
            scanf("%d",&m);
            for(int i=0; i<m; i++)
            {
                int a;
                scanf("%d",&a);
                vec1.push_back(a);
            }
            for(int i=0; i<m; i++)
            {
                int a;
                scanf("%d",&a);
                vec2.push_back(a);
            }
            char c;
            cin>>c;
            if(c==‘<‘)
            {
                sum++;
                for(int i=0; i<m; i++)
                {
                    num[vec1[i]]++;
                    num[vec2[i]]++;
                    if(rem[vec1[i]]==1)
                        rem[vec1[i]]=2;
                    else if(rem[vec1[i]]!=2)
                        rem[vec1[i]]=-1;

                    if(rem[vec2[i]]==-1)
                        rem[vec2[i]]=2;
                    else if(rem[vec2[i]]!=2)
                        rem[vec2[i]]=1;
                }
            }
            else  if(c==‘>‘)
            {
                sum++;
                for(int i=0; i<m; i++)
                {
                    num[vec1[i]]++;
                    num[vec2[i]]++;
                    if(rem[vec1[i]]==-1)
                        rem[vec1[i]]=2;
                    else if(rem[vec1[i]]!=2)
                        rem[vec1[i]]=1;

                    if(rem[vec2[i]]==1)
                        rem[vec2[i]]=2;
                    else if(rem[vec2[i]]!=2)
                        rem[vec2[i]]=-1;
                }
            }
            else
            {
                for(int i=0; i<m; i++)
                {
                    rem[vec1[i]]=2;
                    rem[vec2[i]]=2;
                }
            }
        }
        for(int i=1; i<=n; i++)
        {
            if(rem[i]!=2&&(((num[i]==sum)&&(sum!=0))||sum==0))
            {
                if(ans==0)
                    ans=i;
                else
                {
                    ans=0;
                    break;
                }
            }
        }
        cout<<ans<<endl;
    }
    return 0;
}


poj1029(找假硬币)模拟,布布扣,bubuko.com

poj1029(找假硬币)模拟

原文:http://blog.csdn.net/xiefubao/article/details/24991257

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!