zoukankan      html  css  js  c++  java
  • Kick Start 2018-Round H-Problem C. Let Me Count The Ways

    Problem

    To celebrate the anniversary of Googleland, N couples are going to go for a boat ride in a rowboat. The rowboat is very long, but it is only one person wide, so the people will sit in a line from front to back.

    However, during a rehearsal of the voyage, the boat did not move! After investigating, the organizers found that some newlywed couples were not rowing, but writing love poems for each other the whole time. Specifically, there are M pairs of newlywed couples. If the two members of a newlywed couple are sitting next to each other, they will be so busy writing poems that they will not row.

    Now the organizers have come to you, the smartest person in Googleland, to ask, how many possible ways are there to arrange all 2N people on the rowboat, such that for each of the M newlywed couples, the two members are not sitting next to each other? Two ways are different if there is some position in the boat at which the two ways use different people. Notice that for the purpose of counting the number of ways, the two members of a couple are not considered to be interchangeable. Since the number can be very large, the organizers only want to know the value of the answer modulo 1000000007(109+7).
    Input

    The first line of the input gives the number of test cases, T. T test cases follow. Each test case consists of one line with two integers N and M as described above.
    Output

    For each test case, output one line containing Case #x: y, where x is the test case number (starting from 1) and y is the number of possible arrangements, modulo 1000000007(109+7).
    Limits

    1 ≤ T ≤ 100.
    Small dataset

    1 ≤ M ≤ N ≤ 100.
    Large dataset

    1 ≤ M ≤ N ≤ 100000.
    Sample

    Input
    5
    2 1
    2 2
    3 1
    3 2
    10 5

    Output
    Case #1: 12
    Case #2: 8
    Case #3: 480
    Case #4: 336
    Case #5: 560963525

    In Sample Case #1, there are 2 couples. To make the description simpler, we use the characters A and a to represent the newlywed couple, and B and b to represent the other couple. Per the rules of the problem, A and a cannot be adjacent. There are 12 ways to arrange the four people:
    ABab ABba AbaB AbBa
    aBAb aBbA abAB abBA
    BAba BabA bABa baBA

    In Sample Case #2, both two couples are newlywed couples, so A and a cannot be adjacent, and B and b cannot be adjacent. They can be arranged in the following 8 ways:
    ABab AbaB aBAb abAB
    BAba BabA bABa baBA

    import math
    def c(m,n):
        a = math.factorial(m)//math.factorial(n)
        return a//math.factorial(m-n)
    
    t = int(input())
    for case in range(t):
        [n,m] = input().split(' ')
        n = int(n)
        m = int(m)
        l = 2*n
        count = 0
        flag = -1
        for i in range(m+1):
            flag = -flag
            a = c(m,i)
            b = math.factorial(l-i)
            d = 2**(i)
            count += a*b*d*flag
            # print(a,b,d,count,flag)
            # if count<0:
            #     print(count)
            # (_,count) = divmod(count,1000000007)
        (_, count) = divmod(count, 1000000007)
        print("Case #",end='')
        print(case+1,end='')
        print(": ",end='')
        print(count)
    

    这道题花了两个小时。。因为真心有点麻烦,只通过了small的没有通过large的。
    理解题意不难,输入是两个数字,前一个数字代表有多少对couple,比如2代表是AaBb两对夫妇,然后第二个数字代表有多少对闹矛盾的夫妇。闹矛盾的夫妇是不可以坐在一起的不然他们只会打架就不来划船了。然后让你算有多少组方法。
    这道题放在高中就是一个难一点的排列组合问题嘛。。
    搜了一下,这种题目是有公式的,代公式嘛,我寻思这时间复杂度也不高啊,难道是计算很耗时吗。(那也只能是计算很耗时了)。总之大数据集没有跑出来。

  • 相关阅读:
    微信小程序----导航栏滑动定位(实现CSS3的position:sticky效果)
    微信小程序----侧滑菜单(Popup---左侧滑动,右侧不动)(MUI侧滑导航)
    微信小程序----侧滑菜单(Popup----左侧不动,右侧滑动)(MUI侧滑导航)
    微信小程序----gallery slider(图片轮播)组件
    微信小程序----页面生命周期
    微信小程序----App生命周期
    HDU-1180-诡异的楼梯
    HDU-2031-进制转换
    POJ-1852-Ants
    POJ-2386-Lake Counting
  • 原文地址:https://www.cnblogs.com/bernieloveslife/p/10051248.html
Copyright © 2011-2022 走看看