我的第三篇博客(激动激动真激动!!!)A-B Problem
#210. 差(A-B problem)
题目描述
楠楠在网上刷题,感觉第一题:求两数的和(A+B Problem)太无聊了,于是增加了一题:A-B Problem,难倒了一群小朋友,哈哈。
题目是这样的:给出N个从小到大排好序的整数,一个差值C,要求在这N个整数中找两个数A和B,使得A-B=C,问这样的方案有多少种?
例如:N=5,C=2,5个整数是:2 2 4 8 10。答案是3。
具体方案:第3个数减第1个数;第3个数减第2个数;第5个数减第4个数。
输入输出格式
输入格式:
第一行,两个正整数:N,C。
第二行,N个整数:已经有序。注意:可能有相同的。
输出格式:
一行,一个整数,表示该串数中包含的所有满足A-B=C的数对的方案数。
输入输出样例
4 1
1 1 2 2
4
说明
数据规模:
50%的数据:N的范围是[1...1000]。
100%个数据:N的范围是[1...100000]。
所有数据:C的范围是[1...1000000000],N个整数中每个数的范围是:[0...1000000000]。
----------------------------------------------------------
从现在开始写分析哦!!!(以下为数组计数法分析)
首先,我们可以把A-B problem(A-B=C)改成B+C problem(B+C=A)。
题目中给到了C。如果 B(作为给出的任意整数)+C(已知)后得到的A是给出的整数之一(有这个数)的话,就说明有这一组方案,我们的方案数(sum)就要加一了。
在者,有一个特殊情况,如:
n=6 c=2时
{
1 1 2 2 4 4
}
那么4-2=2就有两种情况,但是会少算一个,所以方案数每次都要加上A数的出现次数(sum+=A数量)。
这个方法可能有些难懂,但是仔细理解就会明白啦~
方法一:(数组计数法)
#include<iostream>
#include<map>
#include<fstream>
#include<algorithm>
#include<cstdio>
using namespace std;
long long b[],n,c;
map<int,int>a;
int sum;
int main()
{
scanf("%d%d",&n,&c);
for(int i=;i<=n;i++)
{
scanf("%d",&b[i]);
a[b[i]]++;
}
for(int i=;i<=n;i++)
{
if(a[b[i]+c])
{
sum+=a[b[i]+c];
}
}
printf("%d",sum); return ;
方法二:(二分查找法)
//程序名:新的C++程序
//作者: #include<iostream>
#include<fstream>
#include<algorithm>
using namespace std;
int sum=;
int num[];
int main()
{
int n,m;
cin>>n>>m;
sum=;
for(int i=;i<n;i++)
{
scanf("%d",&num[i]);
}
for(int k=;k<n;k++)
{
int c=num[k]+m;
int i=,j=n-;
while(i<=j)//二分查找i为left,j为right
{
int mid=(i+j)/;//中间点折半
if(num[mid]==c)
{
sum++;
int p=mid-;
while(num[p]==c&&p>=)
{
p--;
sum++;//加方案数
}
p=mid+;
while(num[p]==c&&p<n)
{
p++;
sum++;//加方案数
}
break;
}
else if(num[mid]>c)
j=mid-;
else
i=mid+;
}
}
cout<<sum; return ;
}
我的第三篇博客(激动激动真激动!!!)A-B Problem的更多相关文章
- java三篇博客转载 详解-vector,stack,queue,deque
博客一:转载自http://shmilyaw-hotmail-com.iteye.com/blog/1825171 java stack的详细实现分析 简介 我们最常用的数据结构之一大概就是stack ...
- 更新glibc版本,有问题,有三篇博客的命令看不懂
https://blog.csdn.net/glongljl/article/details/80156243 https://blog.csdn.net/officercat/article/det ...
- 项目冲刺Beta第三篇博客
Beta版本冲刺计划安排 1.当天站立式会议照片: 2.工作分工: 团队成员 分工 张洪滨060 排行榜界面美化 陈敬轩059 注册成功界面美化 黄兴067 登录界面美化 林国梽068 答题界 ...
- 我的第一篇博客 ——【ToDoList】小程序开发
我是一只即将大四的大三狗,这是我的第一篇博客,说来惭愧.今年1月份,学校放寒假的时候开始自学的IOS,放假的时候比较起劲,看了一堆Object-C的视频,然后照着中英文对照的IOS基础开发教程,做了两 ...
- 這是我既C語言作業寫博客後寫的第一篇博客
這篇博客應該算是寫給我自己的博客吧,所以這裏我想用繁體字寫,因為我漸漸地發現我已經很少使用到繁體字了,日常QQ聊天都使用簡體字,繁體字都懶得切換了,但是為了不讓別人麻煩,在外界交流的時候我會使用簡體字 ...
- [2017BUAA软工]第三次博客作业:案例分析
第三次博客作业:案例分析 1. 调研和评测 1.1 BUG及设计缺陷描述 主要测试博客园在手机端上的使用情况. [BUG 01] 不能后退到上一界面(IOS) 重现步骤:打开博客首页中任意博文,点击博 ...
- 小白两篇博客熟练操作MySQL 之 第一篇
小白两篇博客熟悉操作MySQL 之 第一篇 一.概述 1. 什么是数据库? 答: 储存数据的仓库, 如: 在ATM的事例中创建的一个db 目录, 称为数据库 2. 什么是Mysql, Oracl ...
- 小白两篇博客熟练操作MySQL 之 第二篇
小白两篇博客熟练操作MySQL 之 第二篇 一. 视图 视图是一个虚拟表,其本质是根据SQL语句获取动态的数据集,并为其命名,用户使用时只需使用名称即可获取结果集, 并可以将其当做表来使用. s ...
- 小白神器 - 一篇博客学会HTML
小白神器 - 一篇博客学会HTML 一. 简介 1. HTML 定义 htyper text markup language 即超文本标记语言. 超文本: 就是指页面内可以包含图片.链接,甚至音乐. ...
随机推荐
- 联发科MT8377 MT8389 MT6589 MT6577等芯片详细解析
MT8389大家都比较陌生,但如果我说MT6589估计大家都懂了,实质上MT8389是MT6589的一个分支,一个克隆分支,说得再明了些,就是MT6589的高耗版.如果把它看成是同一个CPU也是可以的 ...
- 【JavaScrpt】JS之数组去重
var arr = [] var peoples = [ {id:1,name:'wang'}, {id:2,name:'zhang'}, {id:2,name:'zhang'}, ] for(let ...
- 英语口语练习系列-C39-舞蹈-谈论昨天的活动
词汇-舞蹈(dancing) ballet body shaking sway the body have a good figure special training arm movement da ...
- 基于for循环的呼吸灯
#include "stm32f10x.h" #include "stm32f10x_gpio.h" //#include "led.h" ...
- http 协议_DNS_域名解析 DNS 服务器_内容分发网络 CDN_缓存机制_HTML5 浏览器存储技术_cookie_sessionStorage_localStorage
TCP/IP 协议族 是按层次去划分的 应用层 决定了向用户提供应用服务时通信的活动. FTP 协议(文件传输协议)DNS(域名协议)HTTP(超文本传输协议) 传输层 提供处于网络连接中 ...
- 2018-2019-1 20189210 《Linux内核原理与分析》第三周作业
一.学习笔记 计算机的"三大法宝" 1.程序存储计算机. 2.函数调用对栈.堆栈的作用是:记录函数调用框架.传递函数参数.保存返回值地址.提供函数内部局部变量的存储空间.函数调用堆 ...
- Java 中的字符串与 []byte 字节数组
一.字符串 1.比较 String.HashSet.List 中的 contains 方法 其中, String.List 都使用了 indexOf 方法,本质是遍历,时间效率为 O(n).而 Has ...
- Oracle 索引 index
索引是一个模式对象,其中包含每个值的条目,该条目出现在表或集群的索引列中,并提供对行的直接快速访问. 创建一个索引: create index 索引名 on 表名 (字段名); 删除索引: dro ...
- HDFS基础配置
HADOOP-3.1.0-----HDFS基础配置 执行步骤:(1)配置集群(2)启动.测试集群增.删.查(3)执行wordcount案例 一.配置集群 1.在 hadoop-env.sh配置文件添加 ...
- shell - shift
Shell编程中Shift的用法 位置参数可以用shift命令左移.比如 shift 3表示原来的$4现在变成$1,原来的$5现在变成$2等等,原来的$1.$2.$3丢弃,$0不移动.不带参数的shi ...