zoukankan      html  css  js  c++  java
  • Codeforces Gym101063 J.The Keys (2016 USP-ICMC)

    J.The Keys

    Out of all science labs constructed by the GEMA mission on Mars, the DSL - Dangerous Species Lab is the most dangerous of them all. The laboratory is so dangerous that you have to go through N doors in succession to get to it. Each one of those doors can only be opened by one key di (notice, however, that there may be different doors that can be opened by the same key).

    A nameless lazy biologist (we'll call him LB) from GEMA needs to open all those doors first thing in the morning, every day. He has all the keys necessary to open them, but he finds carrying all of them in his pockets too much of a mess.

    To be more organized and lose the title of being a lazy biologist, LB purchased Kkey-chains and is planning to distribute all the keys among them. His plan of distribution is very simple. For each key, randomly choose a key-chain with uniform probability and put this key on it.

    When opening the doors, LB will hold one key-chain and will keep the others in his pocket (initially all of them are in his pocket). Whenever he gets to a door that needs a key that is not on the key-chain he is holding, he will swap it with the key-chain that has this key. Getting the first key-chain from his pocket is not considered a swap.

    You have to help LB and find what is the expected number of key-chain swaps he will have to do when opening the doors the next morning.

    Input

    Input begins with N and K (1 ≤ N ≤ 1051 ≤ K ≤ N), the number of doors and the number of key-chains. On the next line there are N numbers di (1 ≤ di ≤ 106), the identifier of the key that opens the i-th door.

    Output

    Output the expected number of swaps. Your answer will be considered correct if the absolute and relative error are less than 10 - 6.

    Example

    Input
    3 3
    1 2 3
    Output
    1.333333333
    Input
    1 1
    2
    Output
    0.000000000
    Input
    5 2
    1 2 3 2 1
    Output
    2.000000000
    
    
    
    

    代码:

     1 #include<iostream>
     2 #include<cstdio>
     3 #include<algorithm>
     4 #include<cstring>
     5 #include<cstdlib>
     6 #include<string.h>
     7 #include<set>
     8 #include<vector>
     9 #include<queue>
    10 #include<stack>
    11 #include<map>
    12 #include<cmath>
    13 using namespace std;
    14 typedef long long ll;
    15 const int N=1e5+10;
    16 const int INF=0x3f3f3f3f;
    17 int a[N];
    18 int main(){
    19     int n,k;
    20     double ans;
    21     while(~scanf("%d%d",&n,&k)){
    22         for(int i=1;i<=n;i++)
    23             scanf("%d",&a[i]);
    24         ans=0;
    25         if(n==1)printf("%.9f
    ",(k-1)*1.0/k);
    26         //if(n==1)printf("%.9f
    ",ans);
    27         else{
    28             for(int i=2;i<=n;i++){
    29                 if(a[i]!=a[i-1])
    30                 ans+=(k-1)*1.0/k;
    31             }
    32             printf("%.9f
    ",ans);
    33         }
    34     }
    35     return 0;
    36 }

    其他的写不出来了。

  • 相关阅读:
    【PHP学习】PHP 变量
    【PHP学习】PHP 语法
    枚举进程使用的DLL
    多线程学习----CreateThread
    C++接口定义及实现举例
    注册表操作(VC_Win32)
    Windows 动态链接库编程
    [代码]JAVA触发器,Spring的quartz配置
    [实例]JAVA调用微信接口发送图文消息,不用跳到详情页
    [实例]JAVA生成字母+随机数字并生成文件
  • 原文地址:https://www.cnblogs.com/ZERO-/p/9695546.html
Copyright © 2011-2022 走看看