zoukankan      html  css  js  c++  java
  • UVA

    Little Tim is now a graduate,and is thinking about higher studies. However, he first needs to appear in anexam whose preparation alone includes memorizing the meanings of over 3500words!

    After going through the list afew times, however, he sees trouble – he can remember all the word-meanings aslong as they keep coming in the same order. When quizzed in random order,however, he is at a complete loss. So, as any decent programmer would, hewrites a random shuffler to help him quiz himself.

    To his dismay, however, hefinds that words that were near each other in the original list quite often endup being close together in the shuffled list as well. He does not like this atall, and suspects that his random shuffler may have some kind of a bug. Butbefore he recodes his shuffler he wants your help to make sure that theshuffler is indeed faulty.

    So he is asking for your helpin determining how likely such events are even if the list is indeed gettingcompletely randomly shuffled, and even if his program is working perfectly.

    Given the size of the list N,and a proximity factor K, you are to determine the expected number of wastedwords in a shuffled list assuming that all possible shufflings are equallylikely. Informally, two words are considered wasted if they appear at adistance less than or equal to K in both the lists. Assume that theoriginal list is cyclical and shuffled list is linear (non-cyclical).

    Formally, let us suppose thattwo words A and B have indices oa and ob inthe original list and indices sa and sb inthe shuffled list, respectively (all indices are 0-based). Then both the wordsare considered wasted if:

    and

    Input

    The input consists of a seriesof cases. Each case consists of two integers N and K on a singleline. You may assume that 1≤K≤N≤100000.Input is terminated by a line containing two 0s, and has at most 125 lines ofinput.

    Output

    Output oneline for each test case except the last one. Each line of output should be ofthe form “Case X: Y”, where X is the serial number of output and Y is  the expected number of wasted words in theshuffled list, printed with exactly four digits after the decimal point, withrounding if necessary.

    SampleInput                             Outputfor Sample Input

    5 2

    5 1

    0 0

    Case 1: 5.0000

    Case 2: 3.5000

    题意:输入n和k,你的任务是计算平均情况下。无效单词的个数,计算方法是:两个单词在又一次排列后的位置不超过k

    思路:我们先计算有效的位置。枚举后。从剩下的选出2*k来计算,用log来计算

    #include <iostream>
    #include <cstdio>
    #include <cstring>
    #include <cmath>
    #include <algorithm>
    using namespace std;
    const int maxn = 100005;
    
    int n, k;
    long double f[maxn];
    
    void solve() {
    	if (n == 1) {
    		printf("0.0000
    ");
    		return;
    	}
    	if (n <= 2 * k + 1) {
    		printf("%d.0000
    ", n);
    		return;
    	}
    
    	int N = k << 1, p;
    	long double sum = 0;
    	for (int i = 1; i <= n; i++) {
    		p = max(i-1-k, 0) + max(n-k-i, 0);
    		if (p < N)
    			continue;
    		sum += exp(f[p] + f[n - N - 1] - f[n - 1] - f[p - N]);
    	}
    	printf("%.4lf
    ", (double)(n - sum));
    }
    
    int main() {
    	f[0] = f[1] = 0;
    	for (int i = 2; i <= maxn; i++)
    		f[i] = f[i-1] + log((long double) i); 
    
    	int cas = 1;
    	while (scanf("%d%d", &n, &k) != EOF && n) {
    		printf("Case %d: ", cas++);
    		solve();
    	}
    	return 0;
    }







    版权声明:本文博客原创文章,博客,未经同意,不得转载。

  • 相关阅读:
    Qt/Qml 电子书阅读器
    Qt/Qml 翻页特效
    vue如何引入本地js(不被打包编译的js)文件
    CSS3解决移动端手指点击或滑动屏幕时出现的浅蓝色背景框
    vue移动端touch插件
    vue组件间通信六种方式(完整版)
    Vue 过渡实现轮播图
    vue中遇到的坑 --- 变化检测问题(数组相关)
    Vue判断设备是移动端还是pc端
    vue项目如何监听窗口变化,达到页面自适应?
  • 原文地址:https://www.cnblogs.com/yxwkf/p/4649396.html
Copyright © 2011-2022 走看看