题目描述

在你的养牛场,所有的奶牛都养在一排呈直线的牛栏中。一共有 n 头奶牛,其中第 i 头牛在直线上所处的位置可以用一个整数坐标 pi​(0≤pi​≤10^8) 来表示。在无聊的日子里,奶牛们常常在自己的牛栏里与其它奶牛交流一些八卦新闻。每头奶牛发出的声音响度是一样的,而由于声波的能量衰减,某头奶牛发出的声音只能被与它距离不超过 d(0≤d≤10^4) 的奶牛所听到,这样这对奶牛就称为可以相互交流的。现在给出所有奶牛的位置和声音所能传播的最远距离 d ,请你编个程序来计算你的养牛场里究竟有多少对可以相互交流的奶牛。

输入格式

第一行包含两个整数 n,d。

第二行包含 n 个整数,每个整数都是一个坐标 p_i​,描述一头奶牛在直线上的位置。

输出格式

一个数,表示养牛场中可以相互交流奶牛的对数。

输入输出样例

输入 #1 复制

5 10

10 12 16 37 40

输出 #1 复制

4

说明/提示

数据规模

对于 40% 的数据,1≤n≤10^3。

对于100% 的数据,1≤n≤10^6。

这是第一道我没有看别人的题解和思路自己写的二分题,所以我现在成就感up,于是赶紧写一篇博客(记录曾经优秀的我)

思路:首先看到这是一道入门题(不要问我为什么会做红题),第一感觉是这个题肯定很水,于是我根本没看取值范围,直接就用了两层循环来做,发现只得了81分,T了两个点。这时候我才发现好像两层循环不能过,n的取值范围是≤10^6,如果套两层循环然后一个个去比较他们之间距离的绝对值是否<d,那么很显然,这是O(n^2)的复杂度,而这样就是O(10^12),很显然这是会裂开的,所以说就要用到二分查找来做。记得当初学分治的时候确实有点难理解。我这次不去刻意的背代码,就是根据自己的理解与思考去写,发现居然A了这个题,说明有的时候还是要相信自己(ง •_•)ง

下面说一下二分:其实就跟书上的二分查找差不多,划定左右区间,然后找左右端点与当前这个点之间的距离的关系。首先我没有用绝对值(可能是我太菜了),那么就要分类讨论,分别将当前奶牛的两边分成两部分,即左边和右边分别二分查找。首先说左边,那么右端点就是当前位置-1,因为你不能和自己交流QWQ,左端点显然是1(我从1开始输入的数组),然后使mid=(left+right)/2,看看mid这个位置和当前位置的距离跟d的关系。如果当前位置与mid的位置距离大于d,那么mid左边的奶牛肯定也和当前位置的奶牛距离大于d,那么你就不用去找了,直接使left=mid+1,这也是二分的精髓之处,可以大大优化时间复杂度。反之,如果距离≤d,那么就说明左边可能还有可以交流的,就继续往左边找,即right=mid-1。就这样一直找一直找,当left>right的时候查找结束,那么这个时候到底left的位置是最远的可以交流的奶牛还是right的位置呢?当时学分治的时候我也有这个疑问。但是其实你只要认真思考一下,就能够绕过这个弯来,我可以分享一下我的理解方法。如果到倒数第二步,距离left>d,而距离right≤d,那么这时候mid就应该在left的位置,因为c++默认整除不了向下取整,那么此时right=mid-1,此时left=mid+1,right也是=mid+1,此时mid=right=left,距离≤d,那么right=mid-1,此时left=mid>mid-1=right,循环结束,那么显然right的位置距离>d,而left≤d,所以left的位置就是可以交流的最远的那只奶牛,设当前奶牛位置为i,那么从left到i算上他们本身是i-left+1,但是i不能和自己交流,所以减1,那么ans+=i-left。这种情况是mid=left=right的位置距离≤d,如果>d,那么left=mid+1,此时mid的位置就应该是交流不到的最近的那只奶牛的位置,那么如果再向右+1,也就是当前的left,就是可以交流到的最远的那只奶牛的位置,所以还是ans+=i-left。从右边二分的时候也是同样的道理,只不过应该是ans+=right-i,下面,上代码!!!

代码:

#include

#include

#include

#include

#include

using namespace std;

long long i,d,n,mid,ans;

long long a[1000010];

int main()

{

cin>>n>>d;

for(i=1;i<=n;i++)

cin>>a[i];

sort(a+1,a+n+1);

for(i=1;i<=n;i++)

{

long long left=1,right=i-1;

while(left<=right)

{

mid=(left+right)/2;

if(a[i]-a[mid]>d) left=mid+1;

else right=mid-1;

}

ans+=i-left;

left=i+1,right=n;

while(left<=right)

{

mid=(left+right)/2;

if(a[mid]-a[i]>d) right=mid-1;

else left=mid+1;

}

ans+=right-i;

}

cout<

return 0;

}

标签:10,right,洛谷,位置,mid,P1296,奶牛,left

来源: https://www.cnblogs.com/57xmz/p/12883882.html

奶牛的耳语c语言,洛谷P1296 奶牛的耳语相关推荐

  1. 洛谷——P1296 奶牛的耳语

    P1296 奶牛的耳语 题目描述 在你的养牛场,所有的奶牛都养在一排呈直线的牛栏中.一共有 nn 头奶牛,其中第 ii 头牛在直线上所处的位置可以用一个整数坐标 p_i(0\le p_i \le 10 ...

  2. 洛谷——P1296 奶牛的耳语(java实现)

    输入格式 第一行包含两个整数 n,dn,d. 第二行包含 nn 个整数,每个整数都是一个坐标 p_ip i ​ ,描述一头奶牛在直线上的位置. 输出格式 一个数,表示养牛场中可以相互交流奶牛的对数. ...

  3. [洛谷P2124] 奶牛美容

    洛谷题目链接:奶牛美容 题目描述 输入输出格式 输入格式: 输出格式: 输入输出样例 输入样例#1: 6 16 ................ ..XXXX....XXX... ...XXXX... ...

  4. 洛谷 P1843 奶牛晒衣服

    题目背景 熊大妈决定给每个牛宝宝都穿上可爱的婴儿装 . 于是 , 为牛宝宝洗晒衣服就成了很不爽的事情. 题目描述 熊大妈请你帮助完成这个重任 . 洗完衣服后 , 你就要弄干衣服 . 衣服在自然条件下用 ...

  5. 洛谷找最小值c语言,洛谷 P1478 陶陶摘苹果(升级版) C语言实现

    原题地址:P1478 淘淘摘苹果(升级版)- 洛谷 题目描述 又是一年秋季时,陶陶家的苹果树结了n个果子.陶陶又跑去摘苹果,这次她有一个a公分的椅子.当他手够不着时,他会站到椅子上再试试. 这次与NO ...

  6. C语言:洛谷,不高兴的津津

    题目描述 津津上初中了.妈妈认为津津应该更加用功学习,所以津津除了上学之外,还要参加妈妈为她报名的各科复习班.另外每周妈妈还会送她去学习朗诵.舞蹈和钢琴.但是津津如果一天上课超过八个小时就会不高兴,而 ...

  7. 洛谷P2181答案C语言,洛谷P2181 对角线(组合数)

    题目描述 对于一个N个定点的凸多边形,他的任何三条对角线都不会交于一点.请求楚图形中对角线交点的个数. 例如,6边形: 输入输出格式 输入格式: 第一行一个n,代表边数. 输出格式: 第一行输出交点数 ...

  8. c语言/洛谷学习笔记之顺序结构(完结)

    洛谷 / 题单列表 / 题单详情 之不会做的题目 1.字母转换 输入一个小写字母,输出其对应的大写字母.例如输入 q[回车] 时,会输出 Q. //方法:我们只需要找到规律:小写字母=大写字母+32, ...

  9. 洛谷 P2345 奶牛集会 解题报告

    P2345 奶牛集会 题目背景 MooFest, 2004 Open 题目描述 约翰的N 头奶牛每年都会参加"哞哞大会".哞哞大会是奶牛界的盛事.集会上的活动很 多,比如堆干草,跨 ...

最新文章

  1. 为什么阿里巴巴禁止使用存储过程?
  2. YCSB benchmark测试cassandra性能——和web服务器测试性能结果类似
  3. Java开发-Redis客户端Jedis
  4. 基于RBF和BP神经网络的信道估计算法的仿真与分析
  5. iqueryable怎么进行操作_钢结构施工要点有哪些?怎么进行操作?
  6. 栈windows linux,Linux+Windows: 程序崩溃时,在 C++ 代码中,如何获取函数调用栈信息...
  7. Arduino笔记-呼吸流水灯
  8. 蓝桥杯单片机:模块代码
  9. thinkphp后台_前后端分离决方案|thinkphpvueadmin 后台接口
  10. homebrew下安装mysql_Mac下homebrew安装Mysql以及配置问题
  11. PMP培训内容有哪些?都要仔细看!
  12. html中scc样式背景渐变,中琅条码生成软件如何制作SCC-14条码
  13. 21cn邮箱服务器端,21CN 免费邮箱常见问题
  14. 计算机房要保持清洁 卫生,国家机房数据安全管理制度
  15. 如何在Vue引入静态图片?
  16. halcon模板匹配实践(5)使用橡皮擦涂抹功能实现减少模板匹配特征
  17. 损失函数(MSE和交叉熵)
  18. “去中心化”是区块链的目的吗
  19. 无人机倾斜摄影—三维建模和DSM,DEM,DOM(正射影像)的生成「CC(Smart3D)),Pix4d,Photoscan,Inpho」
  20. 记一次失败的小米面试

热门文章

  1. 天冷导致电脑无法开机,如何解决?
  2. QT QTextEdit 控件响应回车键
  3. Scroller——startScroll、fling(惯性滑动)
  4. Android(Kotlin)图片按钮,单选框,复选框(实验课)
  5. Android SDK 离线包安装
  6. iOS IAP 自动更新的订阅服务
  7. 滴滴android架构演进,滴滴出行iOS客户端架构演进之路
  8. 请问AppStore上有哪些界面简洁且颜值较高的翻页类时钟App呢?
  9. PyQt5(一)简介
  10. 产品类别二级分类_研究 | 口腔科医疗器械产品分类与监管