zoukankan      html  css  js  c++  java
  • Duizi and Shunzi HDU

    Duizi and Shunzi

    Time Limit: 6000/3000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)
    Total Submission(s): 2883    Accepted Submission(s): 1110


    Problem Description
    Nike likes playing cards and makes a problem of it.

    Now give you n integers, ai(1in)

    We define two identical numbers (eg: 2,2) a Duizi,
    and three consecutive positive integers (eg: 2,3,4) a Shunzi.

    Now you want to use these integers to form Shunzi and Duizi as many as possible.

    Let s be the total number of the Shunzi and the Duizi you formed.

    Try to calculate max(s).

    Each number can be used only once.
     
    Input
    The input contains several test cases.

    For each test case, the first line contains one integer n(1n106). 
    Then the next line contains n space-separated integers ai (1ain)
     
    Output
    For each test case, output the answer in a line.
     
    Sample Input
    7
    1 2 3 4 5 6 7
    9
    1 1 1 2 2 2 3 3 3
    6
    2 2 3 3 3 3
    6
    1 2 3 3 4 5
     
    Sample Output
    2
    4
    3
    2
    Hint
    Case 1(1,2,3)(4,5,6)
    Case 2(1,2,3)(1,1)(2,2)(3,3)
    Case 3(2,2)(3,3)(3,3)
    Case 4(1,2,3)(3,4,5)
     
    Source
     
     
    题意:输入一个n,然后输入n张牌,每张牌都不大于n,问可以组成最多的对子数和顺子数,对子是两个相同的牌,顺子是连续的三张牌
    思路:从1到n遍历, 如果第 i 张牌能打完对子还有多一张,那么看 i+1 张打完对子是不是可以多,如果多的话只要 i+2 有这张牌就可以打出一个顺子,在计算第 i 张牌的时候记得把对子的数量加进去,在可以组成顺子的时候记得把 第 i+1 和 i +2 凑顺子的那一张牌减掉。
     
    #include<iostream>
    #include<cstdio>
    #include<algorithm>
    #include<cstring>
    #include<cmath>
    #include<cstdlib>
    #include<queue>
    #include<set>
    #include<vector>
    using namespace std;
    #define INF 0x3f3f3f3f
    #define eps 1e-10
    #define PI acos(-1.0)
    #define _e exp(1.0)
    #define ll long long
    const int maxn=1e6+5;
    int a[maxn];
    int main()
    {
        int n;
        while(~scanf("%d",&n))
        {
            memset(a,0,sizeof(a));
            int t;
            for(int i=0;i<n;i++)
            {
                scanf("%d",&t);
                a[t]++;
            }
            int ans=0;
            for(int i=1;i<=n;i++)
            {
                ans+=a[i]/2;
                if(i<=n-2 && a[i]%2 && a[i+1]%2 && a[i+2])
                {
                    ans++;
                    a[i]--;
                    a[i+1]--;
                    a[i+2]--;
                }
            }
            printf("%d
    ",ans);
        }
    }
  • 相关阅读:
    Cocos2dx-lua开发之c++绑定到lua
    SCOPE_IDENTITY和@@IDENTITY[转]
    c#List结合IEqualityComparer求交集
    K:java中正则表达式的使用说明及其举例
    K:常见的正则表达式
    K:正则表达式之基础简介
    Q:javax.comm 2.0 windows下Eclipse的配置
    Q:同时安装了python2和python3的电脑下pip的使用
    K:java 断言 assert 初步使用:断言开启、断言使用
    请描述一下 cookies,sessionStorage 和 localStorage 的区别
  • 原文地址:https://www.cnblogs.com/smallhester/p/9600254.html
Copyright © 2011-2022 走看看