博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
我的第三篇博客(激动激动真激动!!!)A-B Problem
阅读量:6272 次
发布时间:2019-06-22

本文共 1832 字,大约阅读时间需要 6 分钟。

#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
#include
#include
#include
#include
using namespace std;long long b[1000010],n,c;map
a;int sum;int main(){ scanf("%d%d",&n,&c); for(int i=1;i<=n;i++) { scanf("%d",&b[i]); a[b[i]]++; } for(int i=1;i<=n;i++) { if(a[b[i]+c]) { sum+=a[b[i]+c]; } } printf("%d",sum); return 0;

方法二:(二分查找法)

//程序名:新的C++程序//作者: #include
#include
#include
using namespace std;int sum=0;int num[10000005];int main(){ int n,m; cin>>n>>m; sum=0; for(int i=0;i
=0) { p--; sum++;//加方案数 } p=mid+1; while(num[p]==c&&p
c) j=mid-1; else i=mid+1; } } cout<

 

转载于:https://www.cnblogs.com/wenzile/p/10716418.html

你可能感兴趣的文章
七天学会ASP.NET MVC (一)——深入理解ASP.NET MVC 【转】
查看>>
Quartz作业调度框架
查看>>
腾讯云下安装 nodejs + 实现 Nginx 反向代理
查看>>
js-权威指南学习笔记13
查看>>
《超级时间整理术》晨读笔记
查看>>
Spring Boot 2.0(二):Spring Boot 2.0尝鲜-动态 Banner
查看>>
Delphi IdTCPClient IdTCPServer 点对点传送文件
查看>>
Delphi中使用ActiveX的一些心得
查看>>
QT5.8.0+MSVC2015安装以及环境配置(不需要安装VS2015)
查看>>
(原創) C/C++的function prototype和header file (C/C++) (C)
查看>>
深入理解JavaScript系列(29):设计模式之装饰者模式
查看>>
程序员的罪与罚
查看>>
SQL*LOADER错误总结
查看>>
SQL日志收缩
查看>>
【转】MySQL Query Cache 小结
查看>>
SVN分支和合并的简单例子
查看>>
PHP实现的封装验证码类
查看>>
Augular初探
查看>>
PHPStorm下XDebug配置
查看>>
【LeetCode】55. Jump Game
查看>>