ACM学习历程—Hihocoder 1177 顺子(模拟 && 排序 && gcd)(hihoCoder挑战赛12)

时间限制:6000ms

单点时限:1000ms

内存限制:256MB

 

描述

你在赌场里玩梭哈,已经被发了4张牌,现在你想要知道发下一张牌后你得到顺子的概率是多少?

假定赌场使用的是一副牌,四种花色的A、2、3、...、J、Q、K共52张,这副牌只发给你了4张,你的剩下一张牌从剩下48张中任意取出一张。

顺子指的是点数连续的五张牌,包括10、J、Q、K、A这种牌型(不包含同花顺,即构成顺子的五张牌花色不能相同)。参见:https://zh.wikipedia.org/wiki/%E6%92%B2%E5%85%8B%E7%89%8C%E5%9E%8B#.E7.89.8C.E5.9E.8B

输入

一行四个被空格隔开的长度为2或3的字符串,XY,表示你手里的牌。

X为2~10、J、Q、K、A中一个,表示点数,Y为S、H、C、D分别表示黑桃、红心、梅花和方块。

输出

一行一个分数表示概率,注意你的分数需为最简分数,若答案为0输出0/1。

样例输入

10S JS QS KD

样例输出

1/6

题目是个模拟,只用暴力枚举每一张牌即可。

最后答案gcd处理公约数以后输出。

代码:

#include <iostream>
#include <cstdio>
#include <cstdlib>
#include <cmath>
#include <cstring>
#include <algorithm>
#include <set>
#include <map>
#include <queue>
#include <string>
#define LL long long

using namespace std;

struct Card
{
    int num;
    char kind;
};

bool cmp(Card a, Card b)
{
    return a.num < b.num;
}

struct node
{
    Card card[5];
}my;

int ans;

//GCD
//求最大公约数
//O(logn)
int gcd(int a, int b)
{
    if (b == 0)
        return a;
    else
        return gcd(b, a%b);
}

bool input()
{
    char str[5];
    for (int i = 0; i < 4; ++i)
    {
        if (scanf("%s", str) == EOF)
            return false;
        if (strlen(str) == 2)
        {
            if (‘2‘ <= str[0] && str[0] <= ‘9‘)
                my.card[i].num = str[0] - ‘0‘;
            else if (str[0] == ‘A‘)
                my.card[i].num = 1;
            else if (str[0] == ‘J‘)
                my.card[i].num = 11;
            else if (str[0] == ‘Q‘)
                my.card[i].num = 12;
            else if (str[0] == ‘K‘)
                my.card[i].num = 13;
            my.card[i].kind = str[1];
        }
        else
        {
            my.card[i].num = 10;
            my.card[i].kind = str[2];
        }
    }
    return true;
}

bool judge(node t)
{
    if (t.card[0].kind == t.card[1].kind &&
        t.card[1].kind == t.card[2].kind &&
        t.card[2].kind == t.card[3].kind &&
        t.card[3].kind == t.card[4].kind)
        return false;
    sort(t.card, t.card+5, cmp);
    if (t.card[0].num+1 == t.card[1].num &&
        t.card[1].num+1 == t.card[2].num &&
        t.card[2].num+1 == t.card[3].num &&
        t.card[3].num+1 == t.card[4].num)
        return true;
    if (t.card[0].num == 1 &&
        t.card[1].num+1 == t.card[2].num &&
        t.card[2].num+1 == t.card[3].num &&
        t.card[3].num+1 == t.card[4].num &&
        t.card[4].num == 13)
        return true;
    return false;
}

void work()
{
    ans = 0;
    for (int i = 1; i <= 13; ++i)
    {
        my.card[4].num = i;
        my.card[4].kind = ‘S‘;
        ans += judge(my);
        my.card[4].kind = ‘H‘;
        ans += judge(my);
        my.card[4].kind = ‘C‘;
        ans += judge(my);
        my.card[4].kind = ‘D‘;
        ans += judge(my);
    }
    int d = gcd(ans, 48);
    if (ans == 0)
        printf("0/1\n");
    else
        printf("%d/%d\n", ans/d, 48/d);
}

int main()
{
    //freopen("test.in", "r", stdin);
    while (input())
    {
        work();
    }
    return 0;
}
时间: 2025-01-03 14:32:14

ACM学习历程—Hihocoder 1177 顺子(模拟 && 排序 && gcd)(hihoCoder挑战赛12)的相关文章

hihocoder #1177 : 顺子 模拟

#1177 : 顺子 Time Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://hihocoder.com/problemset/problem/1177 Description 你在赌场里玩梭哈,已经被发了4张牌,现在你想要知道发下一张牌后你得到顺子的概率是多少? 假定赌场使用的是一副牌,四种花色的A.2.3.....J.Q.K共52张,这副牌只发给你了4张,你的剩下一张牌从剩下48张中任意取出一张. 顺 子指的是点数连续的五张牌,包括10.J.Q

ACM学习历程——HDU4472 Count(数学递推) (12年成都区域赛)

Description Prof. Tigris is the head of an archaeological team who is currently in charge of an excavation in a site of ancient relics.        This site contains relics of a village where civilization once flourished. One night, examining a writing r

ACM学习历程—HDU 4726 Kia&#39;s Calculation( 贪心&amp;&amp;计数排序)

DescriptionDoctor Ghee is teaching Kia how to calculate the sum of two integers. But Kia is so careless and alway forget to carry a number when the sum of two digits exceeds 9. For example, when she calculates 4567+5789, she will get 9246, and for 12

模拟 hihoCoder 1177 顺子

题目传送门 1 /* 2 模拟:简单的照着规则做就可以了,把各种情况考虑到,虽然比赛写的丑了点,但能1Y还是很开心的:) 3 */ 4 #include <cstdio> 5 #include <cstring> 6 #include <iostream> 7 #include <algorithm> 8 #include <cmath> 9 using namespace std; 10 11 const int MAXN = 1e2 + 10

ACM学习历程—HDU 5023 A Corrupt Mayor&#39;s Performance Art(广州赛区网赛)(线段树)

Problem Description Corrupt governors always find ways to get dirty money. Paint something, then sell the worthless painting at a high price to someone who wants to bribe him/her on an auction, this seemed a safe way for mayor X to make money. Becaus

ACM学习历程—UESTC 1226 Huatuo&#39;s Medicine(数学)(2015CCPC L)

题目链接:http://acm.uestc.edu.cn/#/problem/show/1226 题目就是构造一个对称的串,除了中间的那个只有1个,其余的两边都是对称的两个,自然答案就是2*n-1. 代码: #include <iostream> #include <cstdio> #include <cstdlib> #include <cmath> #include <cstring> #include <algorithm> #

ACM学习历程—Hihocoder 1233 Boxes(bfs)(2015北京网赛)

hihoCoder挑战赛12 时间限制:1000ms 单点时限:1000ms 内存限制:256MB   描述 There is a strange storehouse in PKU. In this storehouse there are n slots for boxes, forming a line. In each slot you can pile up any amount of boxes. The limitation is that you can only pile a

hihocoder 1177 : 顺子

#1177 : 顺子 时间限制:6000ms 单点时限:1000ms 内存限制:256MB 描述 你在赌场里玩梭哈,已经被发了4张牌,现在你想要知道发下一张牌后你得到顺子的概率是多少? 假定赌场使用的是一副牌,四种花色的A.2.3.....J.Q.K共52张,这副牌只发给你了4张,你的剩下一张牌从剩下48张中任意取出一张. 顺 子指的是点数连续的五张牌,包括10.J.Q.K.A这种牌型(不包含同花顺,即构成顺子的五张牌花色不能相同).参 见:https://zh.wikipedia.org/wi

ACM学习历程—HDU 3092 Least common multiple(数论 &amp;&amp; 动态规划 &amp;&amp; 大数)

hihoCoder挑战赛12 Description Partychen like to do mathematical problems. One day, when he was doing on a least common multiple(LCM) problem, he suddenly thought of a very interesting question: if given a number of S, and we divided S into some numbers