LightOJ 1027 A Dangerous Maze 概率期望

LightOJ 1027 A Dangerous Maze 概率期望

大家好,又见面了,我是全栈君。

  题目链接: https://vjudge.net/problem/LightOJ-1027

  题目描述: 有N个门, 每个门的选择是等概率的, 如果选择到正数, 我将在正数秒后逃出迷宫, 如果是负数就重新选, 问逃离的期望时间是多少

  解题思路: 我这道题犯蠢了, 我认为是…..说不太明白, 看程序吧, 一下子就能看懂, 其中涉及到了一个约分, 但是我没想到就算是long long 也会溢出, 那么我将约分放进每次mul中呢? 也是不行的, 因为都是素数呢, 不是一样会溢出? 自己在半个小时后才意识到这个蠢问题………

        正确解法是 Y = P1 * T1 + P2 * (T2 + Y) 移项就可以整理出Y = 正数个数的倒数 * ∑abs(Xi) , 再将0的情况单独扣出去就可以了

  代码: 下面第一个是我的错误代码, 谨记

LightOJ 1027 A Dangerous Maze 概率期望
LightOJ 1027 A Dangerous Maze 概率期望

#include <iostream>
#include <cstdio>
#include <string>
#include <vector>
#include <cstring>
#include <iterator>
#include <cmath>
#include <algorithm>
#include <stack>
#include <deque>
#include <map>
#include <set>
#include <queue>
#define lson l, m, rt<<1
#define rson m+1, r, rt<<1|1
#define mem0(a) memset(a,0,sizeof(a))
#define mem1(a) memset(a,-1,sizeof(a))
#define sca(x) scanf("%d",&x)
//#define de printf("=======\n")
typedef long long ll;
using namespace std;

ll x[103];

ll gcd(ll a, ll b) {
    return b==0 ? a : gcd(b, a%b);
}

struct node {
    ll nu;
    ll de;
    node() { nu = de = 1; }
    void mul(ll x, ll y) {
        nu *= x;
        de *= y;
        ll g = gcd(nu, de);
        nu /= g, de /= g;
    }
    void sim() {
        ll g = gcd(nu, de);
        nu /= g, de /= g;
    }
};


int main() {
    int t;
    sca(t);
    int cases = 1;
    while( t-- ) {
        ll n;
        scanf( "%lld", &n );
        ll cnt = 0;
        ll sum = 0;
        for( int i = 0; i < n; i++ ) {
            scanf( "%lld", &x[i] );
            if( x > 0 ) {
                sum += x[i];
                cnt++;
            }
        }
        if( cnt == 0 ) {
            printf( "Case %d: inf\n", cases++ );
            continue;
        }
        else if( cnt == n ) {
            node temp;
            for( ll i = 0; i < n; i++ ) {
                temp.mul(x[i], n);
            }
            if( temp.nu == 0 || temp.de == 0 ) while(1) {}
            temp.sim();
            printf( "Case %d: %lld/%lld\n", cases++, temp.nu, temp.de );
            continue;
        }
        node res;
        res.mul(sum*n, cnt);
        res.mul(n-cnt, cnt);
        res.sim();
        printf( "Case %d: %lld/%lld\n", cases++, res.nu, res.de );
    }
    return 0;
}

View Code

 

LightOJ 1027 A Dangerous Maze 概率期望
LightOJ 1027 A Dangerous Maze 概率期望

#include <iostream>
#include <cstdio>
#include <string>
#include <vector>
#include <cstring>
#include <iterator>
#include <cmath>
#include <algorithm>
#include <stack>
#include <deque>
#include <map>
#include <set>
#include <queue>
#define lson l, m, rt<<1
#define rson m+1, r, rt<<1|1
#define mem0(a) memset(a,0,sizeof(a))
#define mem1(a) memset(a,-1,sizeof(a))
#define sca(x) scanf("%d",&x)
//#define de printf("=======\n")
typedef long long ll;
using namespace std;

int gcd(int a, int b) {
    return b == 0 ? a : gcd(b, a%b);
}

int main() {
    int t;
    sca(t);
    int cases = 1;
    while( t-- ) {
        int n;
        sca(n);
        int sum = 0;
        int cnt = 0;
        for( int i = 0; i < n; i++ ) {
            int x;
            sca(x);
            sum += abs(x);
            if( x > 0 ) cnt++;
        }
        if( cnt == 0 ) {
            printf( "Case %d: inf\n", cases++ );
            continue;
        }
        int g = gcd(sum, cnt);
        sum /= g;
        cnt /= g;
        printf( "Case %d: %d/%d\n", cases++, sum, cnt );
    }
    return 0;
}

AC

  思考: 在想算法之后, 在写代码之前一定要这个算法代码到底能不能实现, 像我这个De了半个多小时的BUG才发现算法能算出来, 就是无法实现, 以后先公式, 看能不能公式出来, 概率题好多都是这样的

转载于:https://www.cnblogs.com/FriskyPuppy/p/7519995.html

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/108159.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 网站的域名带www的和不带www的有什么区别呀

    网站的域名带www的和不带www的有什么区别呀

    2021年10月25日
    91
  • Windows下dos中 copy命令的实现

    Windows下dos中 copy命令的实现实现的的功能:复制文件功能一:功能分析1.1windows系统下的dos命令中指令copy能实现文件的复制。比如:copylog.txtlog1.txt就是将log.txt文件复制一份,复制后的文件名称为log1.txt图例:1.2copy命令实现要求:自己创造一个命令,比如:test.exelog.txttest.bak有三个参数,第一个参…

    2022年7月18日
    16
  • 什么是bs模型_cs模型人物看不见

    什么是bs模型_cs模型人物看不见C/S结构,即Client/Server(客户机/服务器)结构,是大家熟知的软件系统体系结构,通过将任务合理分配到Client端和Server端,降低了系统的通讯开销,可以充分利用两端硬件环境的优势。早期的软件系统多以此作为首选设计标准。(用的是ip,tcp/udp通信协议)B/S结构,即Browser/Server(浏览器/服务器)结构,是随着Internet技术的兴起,对C/S结构的一种…

    2022年9月17日
    0
  • Graphics2D 绘制图形

    Java语言在Graphics类提供绘制各种基本的几何图形的基础上,扩展Graphics类提供一个Graphics2D类,它拥用更强大的二维图形处理能力,提供、坐标转换、颜色管理以及文字布局等更精确的控制。绘图属性Graphics2D定义了几种方法,用于添加或改变图形的状态属性。可以通过设定和修改状态属性,指定画笔宽度和画笔的连接方式;设定平移、旋转、缩放或修剪变换图形;以及设定填充图

    2022年4月13日
    98
  • C#中什么是泛型

    C#中什么是泛型参考视频c#教程泛型集合与非泛型集合最大的区别在于,泛型集合,不需要进行装箱和拆箱的操作。如集合元素为值类型,通常泛型集合要优于非泛型集合,并优于从非泛型集合派生出来的类型,泛是广泛的意思,而型是数据类型。这里的泛型可以理解为应用广泛的数据类型。为了提高性能及维护类型安全,一般最好采用泛型集合。如果两个类的内容完全一样,只是处理的数据类型不同。那么,采用泛型是一个不错的选择。泛型类用于封装不是特定于具体数据类型的操作,通常用于集合。诸如从集合中添加和移除项这样的操作都以大体上相同的方式执行,与所存

    2022年6月16日
    31
  • Dubbo负载均衡策略之 一致性哈希

    Dubbo负载均衡策略之 一致性哈希Dubbo负载均衡策略之一致性哈希1负载均衡在这里引用dubbo官网的一段话——LoadBalance中文意思为负载均衡,它的职责是将网络请求,或者其他形式的负载“均摊”到不同的机器上。避免集群中部分服务器压力过大,而另一些服务器比较空闲的情况。通过负载均衡,可以让每台服务器获取到适合自己处理能力的负载。在为高负载服务器分流的同时,还可以避免资源浪费,一举两得。负载均衡可分为软件负载均衡和硬件负载均衡。在我们日常开发中,一般很难接触到硬件负载均衡。但软件负载均衡还是可以接触到的,比如Nginx

    2022年7月27日
    5

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号