zoukankan      html  css  js  c++  java
  • Game with Pearls

    Problem Description
    Tom and Jerry are playing a game with tubes and pearls. The rule of the game is:
    1) Tom and Jerry come up together with a number K. 
    2) Tom provides N tubes. Within each tube, there are several pearls. The number of pearls in each tube is at least 1 and at most N. 
    3) Jerry puts some more pearls into each tube. The number of pearls put into each tube has to be either 0 or a positive multiple of K. After that Jerry organizes these tubes in the order that the first tube has exact one pearl, the 2nd tube has exact 2 pearls, …, the Nth tube has exact N pearls.
    4) If Jerry succeeds, he wins the game, otherwise Tom wins. 
    Write a program to determine who wins the game according to a given N, K and initial number of pearls in each tube. If Tom wins the game, output “Tom”, otherwise, output “Jerry”.
     
    Input
    The first line contains an integer M (M<=500), then M games follow. For each game, the first line contains 2 integers, N and K (1 <= N <= 100, 1 <= K <= N), and the second line contains N integers presenting the number of pearls in each tube.
     
    Output
    For each game, output a line containing either “Tom” or “Jerry”.
     
    Sample Input
    2 5 1 1 2 3 4 5 6 2 1 2 3 4 5 5
     
    Sample Output
    Jerry Tom
     
    Source
     

    题意:给你n个数,(1<=n<=100),还有一个k(1<=k<=n),然后允许给某一个数加上k的正整数倍,当然可以不加,问你是否可以把这n个数变成1,2,3,...,n,可以就输出Jerry,否则输出Tom。

    分析:一开始直接开个100数组去记录每个数出现的次数。。。如果某一个数出现了,那就不用动这个数了,对于没出现的数,枚举要加的数(k,2k,3k,...注意边界,不能超过这个数)。如果存在某一个数没出现而且不能通过别的数加若干个k,直接判断不能实现 。。简简单单就过了

     

    来源:http://mathlover.info/archives/hdu5090

     

    代码:

     1 #include<iostream>
     2 #include<cstring>
     3 #include<cstdio>
     4 using namespace std;
     5 
     6 int main()
     7 {
     8     int m,n,k;
     9     cin>>m;
    10     int a[105],cnt[102];
    11     bool p[105];
    12     while(m--)
    13     {
    14         cin>>n>>k;
    15         memset(cnt,0,sizeof(cnt));
    16         memset(p,0,sizeof(p));
    17 
    18         for(int i=0;i<n;i++)
    19         {
    20             cin>>a[i];
    21             if(p[a[i]]==0)///判断出现的标志
    22                 p[a[i]]=1;
    23             else
    24                 cnt[a[i]]++;///多余的数字
    25         }
    26 
    27         bool flag=1;///标记谁能赢
    28         for(int i=1;i<=n;i++)
    29         {
    30             if(p[i]==0)///如果这个数没有出现
    31             {
    32                 bool ok=0;
    33                 for(int j=1;i-j*k>=1;j++)///依次减去k的倍数
    34                 {
    35                     if(cnt[i-j*k])///若多余
    36                     {
    37                         cnt[i-j*k]--;
    38                         ok=1;
    39                         break;///即是可以由多余的数字变化而来,逆过程
    40                     }
    41                 }
    42                 if(!ok)///ok==0-------若果没有找到,则进行此if
    43                 {
    44                     flag=0;
    45                     break;
    46                 }
    47             }
    48         }
    49 
    50         if(flag)
    51             puts("Jerry");
    52         else
    53             puts("Tom");
    54     }
    55     return 0;
    56 }
     
  • 相关阅读:
    osworkflow
    用Flash做报表,推荐使用Flash饼图
    ANT 发布项目中 build.xml 文件的详细配置
    tomcat 修改java后不重启的方法
    工厂方法(Factory Method)模式
    NSRunLoop概述和原理
    使用NSOperationQueue简化多线程开发
    使用Grad Central Dispatch简化iPhone开发
    进度显示例子学习
    深入浅出 iOS 之多线程
  • 原文地址:https://www.cnblogs.com/moqitianliang/p/4788468.html
Copyright © 2011-2022 走看看