题意:

      有一个车站,两个人想要在这个车站见面,第一个人会在t1到t2之间的任意一个时刻到(时间上任意一点概率一样),并且停留w时间,第二个人是s2到s2的时间段到,停留也是w,问两个人的见面概率是多少?

思路:

      这个应该算是个比较经典的问题了吧,感觉在那看到过,我们建立一个直角坐标系,t1<=x<=t2 ,s1<=y<=s2这样构成的这个矩形就是所有的概率区间,然后画一条x=y的直线,然后把这个直线沿着x=y方向想下和向上平移w得到一个区间,这个区间和句型重叠的部分就是见面的概率区间,用这个面积除以矩形的面积就是见面概率,求面积的时候我的方法比较笨,y=x+w,y=x-w这两条直线分别和四条线段求交点,然后在根据得到的四个交点的位置分布,枚举求出答案,我写的比较麻烦!

#include<stdio.h>

#include<string.h>

int main ()

{

   double t1 ,t2 ,s1 ,s2 ,w ,x ,y;

   double x1 ,x11 ,y1 ,y11;

   double x2 ,x22 ,y2 ,y22;

   int mark1[5] ,mark2[5];

   int t ,cas = 1;

   scanf("%d" ,&t);

   while(t--)

   {

      scanf("%lf %lf %lf %lf %lf" ,&t1 ,&t2 ,&s1 ,&s2 ,&w);

      int mk = 0; 

      memset(mark1 ,0 ,sizeof(mark1));

      memset(mark2 ,0 ,sizeof(mark2));

      // 1

      y = t1 + w;

      if(y >= s1)

      {

         if(y >= s2) y = s2;

         if(mk <= 2)

         if(mk == 0) x1 = t1 ,y1 = y;

         else x11 = t1 ,y11 = y;

         mark1[1] = 1;

         mk ++;

      }

       //4

      x = s1 - w;

      if(x >= t1)

      {

         mark1[4] = 1;

         if(x >= t2) x = t2;

         if(mk <= 2)

         if(mk == 0) x1 = x ,y1 = s1;

         else x11 = x ,y11 = s1;

         mk ++;

      }

      

      //3

      y = t2 + w;

      if(y <= s2)

      {

         mark1[3] = 1;

         if(y < s1) y = s1;

         if(mk <= 2)

         if(mk == 0) x1 = t2 ,y1 = y;

         else x11 = t2 ,y11 = y;

         mk ++;

      }

      //2

      x = s2 - w;

      if(x <= t2)

      {

         mark1[2] = 1;

         if(x < t1) x = t1;

         if(mk <= 2)

         if(mk == 0) x1 = x ,y1 = s2;

         else x11 = x ,y11 = s2;

         mk ++;

      }

     

      

      

      mk = 0; 

      // 1

      y = t1 - w;

      if(y >= s1)

      {

         mark2[1] = 1;

         if(y >= s2) y = s2;

         if(mk <= 2)

         if(mk == 0) x2 = t1 ,y2 = y;

         else x22 = t1 ,y22 = y;

         mk ++;

      }

      

      //4

      x = s1 + w;

      if(x >= t1)

      {

         mark2[4] = 1;

         if(x >= t2) x = t2;

         if(mk <= 2)

         if(mk == 0) x2 = x ,y2 = s1;

         else x22 = x ,y22 = s1;

         mk ++;

      }

      //3

      y = t2 - w;

      if(y <= s2)

      {

         mark2[3] = 1;

         if(y < s1) y = s1;

         if(mk <= 2)

         if(mk == 0) x2 = t2 ,y2 = y;

         else x22 = t2 ,y22 = y;

         mk ++;

      }

      //2

      x = s2 + w;

      if(x <= t2 )

      {

         mark2[2] = 1;

         if(x < t1) x = t1;

         if(mk <= 2)

         if(mk == 0) x2 = x ,y2 = s2;

         else x22 = x ,y22 = s2;

         mk ++;

      }

      

      

      if(x1 == x11 && y1 == y11 && x2 == x22 && y2 == y22 && x1 ==x2 && y1 == y2)

      {

         printf("Case #%d: 0.00000000" ,cas ++);

         continue;

      }

      double m1 ,m2;

      double m = (t2 - t1) * (s2 - s1);

      if(mark1[1] && mark1[2]) m1 = (s2 - y1) * (x11 - t1) / 2;

      else if(mark1[1] && mark1[3]) m1 = ((s2 - y1) + (s2 - y11)) * (t2 - t1) / 2;

      else if(mark1[4] && mark1[2]) m1 = ((x1 - t1) + (x11 - t1)) * (s2 - s1) / 2;

      else if(mark1[4] && mark1[3]) m1 = m -  (y11 - s1) * (t2 - x1) / 2;

      

      if(mark2[1] && mark2[2]) m2 =  m - (s2 - y2) * (x22 - t1) / 2;

      else if(mark2[1] && mark2[3]) m2 = m - ((s2 - y2) + (s2 - y22)) * (t2 - t1) / 2;

      else if(mark2[4] && mark2[2]) m2 = m - ((x2 - t1) + (x22 - t1)) * (s2 - s1) / 2;

      else if(mark2[4] && mark2[3]) m2 = (y22 - s1) * (t2 - x2) / 2;

      

      double Ans = (m - (m1 + m2)) / m;

      printf("Case #%d: %.8lf\n" ,cas ++ ,Ans);

      

   }

   return 0;

}

      

         

      

      

         

      

         

         

         

         

      

      

      

UVA11722(见面概率)的更多相关文章

  1. UVA 11722

    You are going from Dhaka to Chittagong by train and you came to know one of your old friends is goin ...

  2. UVA11722概率问题之线性规划

    链接:http://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_problem&am ...

  3. uva11722 - Joining with Friend(几何概率)

    11722 - Joining with Friend You are going from Dhaka to Chittagong by train and you came to know one ...

  4. uva 11722 - Joining with Friend(概率)

    题目连接:uva 11722 - Joining with Friend 题目大意:你和朋友乘火车,而且都会路过A市.给定两人可能到达A市的时段,火车会停w.问说两人能够见面的概率. 解题思路:y = ...

  5. PHP常见面试题汇总(二)

    PHP常见面试题汇总(二)   //第51题:统计一维数组中所有值出现的次数?返回一个数组,其元素的键名是原数组的值;键值是该值在原数组中出现的次数 $array=array(4,5,1,2,3,1, ...

  6. LightOJ.1265.Island of Survival(概率)

    题目链接...我找不着了 \(Description\) 岛上有t只老虎,1个人,d只鹿.每天随机有两个动物见面 1.老虎和老虎碰面,两只老虎就会同归于尽: 2.老虎和人碰面或者和鹿碰面,老虎都会吃掉 ...

  7. ZOJ 3551 Bloodsucker <概率DP>

    题目:http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemCode=3551 题意:开始有N-1个人和一个吸血鬼, 每天有两个生物见面,当人 ...

  8. Gym - 101987G Secret Code (概率+数学积分)

    题意:有A,B,C三个人要见面,每个人在[0,S]随机选择一个时间点作为见面时间,先到的那个人要等下一个人来了之后和他确认信息,然后马上就走. 例如,假如A先到,B其次,C最后到,那么A要等B到了之后 ...

  9. [bzoj2152][聪聪和可可] (点分治+概率)

    Description 聪聪和可可是兄弟俩,他们俩经常为了一些琐事打起来,例如家中只剩下最后一根冰棍而两人都想吃.两个人都想玩儿电脑(可是他们家只有一台电脑)……遇到这种问题,一般情况下石头剪刀布就好 ...

随机推荐

  1. 聊聊IT技术人的知识体系

    我在我的2020年终总结中提到技术人需要建立自己的知识体系,那么怎么建立自己的知识体系呢?技术人的知识体系又是什么样的呢?今天,和你一一分享. 1 关于我的12字方针 我在我的<2020年终回顾 ...

  2. Netty源码 新连接处理

    上文我们阐述了Netty的Reactor模型.在Reactor模型的第二阶段,Netty会处理各种io事件.对于客户端的各种请求就是在这个阶段去处理的.本文便来分析一个新的连接是如何被处理的. 代码的 ...

  3. 爬虫入门到放弃系列05:从程序模块设计到代理IP池

    前言 上篇文章吧啦吧啦讲了一些有的没的,现在还是回到主题写点技术相关的.本篇文章作为基础爬虫知识的最后一篇,将以爬虫程序的模块设计来完结. 在我漫(liang)长(nian)的爬虫开发生涯中,我通常将 ...

  4. spring事务:事务控制方式,使用AOP控制事务,七种事务传播行为,声明事务,模板对象,模板对象原理分析

    知识点梳理 课堂讲义 1)事务回顾 1.1)什么是事务-视频01 事务可以看做是一次大的活动,它由不同的小活动组成,这些活动要么全部成功,要么全部失败. 1.2)事务的作用 事务特征(ACID) 原子 ...

  5. python对一个文本的解析

    # 定义Tag的签注 controlAreaStart ="<ControlArea::黄冈>" controlAreaEnd = "</Control ...

  6. Nodejs学习笔记(2) 阻塞/非阻塞实例 与 Nodejs事件

    1. Node.js异步编程的特点 2. 阻塞与非阻塞的实例 2.1 阻塞代码实例 2.2 非阻塞代码实例 3. Node.js的事件驱动 4. 事件循环实例 1. Node.js异步编程的特点 参考 ...

  7. 输出质数(Java)

    输出质数 一.什么是质数 质数又称素数.一个大于1的自然数,除了1和它自身外,不能被其他自然数整除的数叫做质数,否则称为合数(规定1既不是质数也不是合数). 二.代码实现 1.输出100以内的质数 i ...

  8. Lombok 常用注解总结

    本文转载自知乎专栏 极乐科技.有所整理. 主要注解 @Data @Setter @Getter @Log4j @AllArgsConstructor @NoArgsConstructor @Equal ...

  9. Just a Joke HDU - 4969(物理+积分)

    题目链接:https://vjudge.net/problem/HDU-4969#author=0 题意:一个人在圆心以V2速度追赶一个以V1的速度进行圆周运动,问在圆心的人能否在不超过D的距离追上他 ...

  10. Java 并发编程 生产者消费者模式

    本文部分摘自<Java 并发编程的艺术> 模式概述 在线程的世界里,生产者就是生产数据的线程,消费者就是消费数据的数据.生产者和消费者彼此之间不直接通信,而是通过阻塞队列进行通信,所以生产 ...