本题基本思路:先对原序列进行排序,再根据不同情况采用不同算法。

首先差最大的对数最好求:用最小的数的个数 × 最大的数的个数即可。

接着求差最小的对数:

1.当序列中无重复关键字时:可知最小差必然产生在相邻元素中,遍历一遍用map保存最小差的对数即可。

2.当序列中有重复关键字时:首先确定最小差为0,故而对相同序列的个数依次用排列组合的知识求对数即可。

AC代码如下:

 #include <bits/stdc++.h>
using namespace std; vector<int> ivec;
int n, item, mindis, imin, imax, iequ;
map<int, int> imap;
bool flag; int main()
{
while(cin >> n)
{
ivec.clear();//每次读取n之后都要清空ivec
for(int i = ; i < n; ++i)
{
cin >> item;
ivec.push_back(item);
}
stable_sort(ivec.begin(), ivec.end());
mindis = INT_MAX;
int len = ivec.size();
imin = imax = ;
iequ = ;
flag = false;
imap.clear();
for(int i = ; i < len-; ++i)
{
if(ivec[i] > ivec[] && ivec[i-] == ivec[])
imin = i;
if(ivec[i] < ivec[len-] && ivec[i+] == ivec[len-])
imax = len--i;
if(ivec[i] == ivec[i+])
flag = true;
}
if(flag == true)
{
mindis = ;
for(int i = ; i < len-; ++i)
{
if(ivec[i+] == ivec[i])
{
iequ++;
}
else {
if(iequ > )
{
imap[mindis] += iequ*(iequ-)/;
iequ = ;
}
}
}
if(iequ > ) //考虑相同关键字序列在末尾
imap[mindis] += iequ*(iequ-)/;
} else {
for(int i = ; i < len-; ++i)
{
if(abs(ivec[i+]-ivec[i]) <= mindis)//注意是<=
{
mindis = abs(ivec[i+]-ivec[i]);
imap[mindis]++;
}
}
}
cout << imap[mindis] << " " << imin*imax << endl;
} return ;
}
 import java.util.*;

 public class Main {
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
while(sc.hasNext()) {
int n = sc.nextInt();
int [] a = new int[n];
for (int i = 0; i < n; ++i) {
a[i] = sc.nextInt();
}
Arrays.sort(a);
boolean flag = false;
int imin = 0, imax = 0;
for (int i = 0; i < n-1; ++i) {
if(a[i] == a[i+1])
flag = true;
if(a[i] == a[0] && a[i+1] != a[0])
imin = i+1;
if(a[i] != a[n-1] && a[i+1] == a[n-1])
imax = n - 1 - i;
} int mindis = 1000000000; ;
Map<Integer, Integer> map = new TreeMap<>(); if(flag) {
mindis = 0;
int iequ = 1;
for (int i = 0; i < n-1; ++i) {
if(a[i] == a[i+1]) {
iequ++;
} else {
if (map.containsKey(mindis))
map.put(mindis, map.get(mindis)+iequ*(iequ-1)/2);
else
map.put(mindis, iequ*(iequ-1)/2);
iequ = 1;
}
}
if (iequ > 1) {
if (map.containsKey(mindis))
map.put(mindis, map.get(mindis)+iequ*(iequ-1)/2);
else
map.put(mindis, iequ*(iequ-1)/2);
iequ = 1;
}
} else {
for (int i = 0; i < n-1; ++i) {
if (Math.abs(a[i+1]-a[i]) <= mindis) {
mindis = Math.abs(a[i+1]-a[i]);
if (map.containsKey(mindis))
map.put(mindis, map.get(mindis)+1);
else
map.put(mindis, 1);
}
}
}
System.out.println(map.get(mindis) + " " + imin*imax);
}
sc.close();
}
}

这题AC关键是注意细节:每次读取n之后容器、变量的初始化、有重复关键字在序列末尾的情况、无重复关键字时求最小差对数比较符号的选择等。

算法编程题积累(4)——腾讯笔试"有趣的数字“问题的更多相关文章

  1. 算法编程题积累(3)——腾讯笔试"构造回文“问题

    首先理解题意,回文串的特点:倒序后跟原串相同.故而可以将原串看成向一个回文串在任意位置添加任意字符后形成的字符串,也就是说原串中存在一段未必连续的回文序列. 通过分析可以知道AC本题的核心思路:求出回 ...

  2. 算法编程题积累(1)——网易笔试"工程师工作安排“问题

    首先理解题目意思:每个人只能做工作序号表里的一件工作且两个人不能同时做一件工作.AC思路:采用暴力枚举每种可能的分配方案,子问题的解决逐步向上解决了母问题,最终原问题得解. 标程作者:NotDeep( ...

  3. C算法编程题系列

    我的编程开始(C) C算法编程题(一)扑克牌发牌 C算法编程题(二)正螺旋 C算法编程题(三)画表格 C算法编程题(四)上三角 C算法编程题(五)“E”的变换 C算法编程题(六)串的处理 C算法编程题 ...

  4. C算法编程题(七)购物

    前言 上一篇<C算法编程题(六)串的处理> 有些朋友看过我写的这个算法编程题系列,都说你写的不是什么算法,也不是什么C++,大家也给我提出用一些C++特性去实现问题更方便些,在这里谢谢大家 ...

  5. C算法编程题(六)串的处理

    前言 上一篇<C算法编程题(五)“E”的变换> 连续写了几篇有关图形输出的编程题,今天说下有关字符串的处理. 程序描述 在实际的开发工作中,对字符串的处理是最常见的编程任务.本题目即是要求 ...

  6. C算法编程题(五)“E”的变换

    前言 上一篇<C算法编程题(四)上三角> 插几句话,说说最近自己的状态,人家都说程序员经常失眠什么的,但是这几个月来,我从没有失眠过,当然是过了分手那段时期.每天的工作很忙,一个任务接一个 ...

  7. C算法编程题(四)上三角

    前言 上一篇<C算法编程题(三)画表格> 上几篇说的都是根据要求输出一些字符.图案等,今天就再说一个“上三角”,有点类似于第二篇说的正螺旋,输出的字符少了,但是逻辑稍微复杂了点. 程序描述 ...

  8. C算法编程题(三)画表格

    前言 上一篇<C算法编程题(二)正螺旋> 写东西前还是喜欢吐槽点东西,要不然写的真还没意思,一直的想法是在博客园把自己上学和工作时候整理的东西写出来和大家分享,就像前面写的<T-Sq ...

  9. C算法编程题(二)正螺旋

    前言 上一篇<C算法编程题(一)扑克牌发牌> 写东西前总是喜欢吐槽一些东西,还是多啰嗦几句吧,早上看了一篇博文<谈谈外企涨工资那些事>,里面楼主讲到外企公司包含的五类人,其实不 ...

随机推荐

  1. 02-28 scikit-learn库之线朴素贝叶斯

    目录 scikit-learn库之朴素贝叶斯 一.MultinomialNB 1.1 使用场景 1.2 代码 1.3 参数详解 1.4 属性 1.5 方法 二.GaussianNB 三.Bernoul ...

  2. Huffman树及其编解码

    Huffman树--编解码 介绍:   Huffman树可以根据输入的字符串中某个字符出现的次数来给某个字符设定一个权值,然后可以根据权值的大小给一个给定的字符串编码,或者对一串编码进行解码,可以用于 ...

  3. Kotlin 中的伴生对象和静态成员

    用了一段时间kotlin,越用越觉得好用,爱不释手啊,留点笔记. Kotlin 中,在类中定义的对象(object)声明,可使用 companion 修饰,这样此对象(object)就是伴生对象了.类 ...

  4. Python 爬虫 爬取 煎蛋网 图片

    今天, 试着爬取了煎蛋网的图片. 用到的包: urllib.request os 分别使用几个函数,来控制下载的图片的页数,获取图片的网页,获取网页页数以及保存图片到本地.过程简单清晰明了 直接上源代 ...

  5. 采用WPF开发截图程序,so easy!

    前言  QQ.微信截图功能已很强大了,似乎没必要在开发一个截图程序了.但是有时QQ热键就是被占用,不能快速的开启截屏:有时,天天挂着QQ,领导也不乐意.既然是程序员,就要自己开发截屏工具,功能随心所欲 ...

  6. Git上传到gitlab现有分支

    [场景]gitlab上已经创建了分支,将本地的文件上传到该分支下 gitlab上的现有分支branch_new 在需要上传的文件夹下打开git命令窗口 # 克隆远端分支到本地 git clone -b ...

  7. PHP array_mulitsort

    1.函数的作用:对多维数组进行排序 2.函数的例子: 例子一: <?php // http://php.net/manual/zh/function.array-multisort.php $m ...

  8. SSO原理解析

    什么是单点登录 简单点说就是公司有A,B两个系统,我登录了A系统之后再跳转到B系统可以直接访问,而不需要再次登录B系统. 几种常见的单点登录实现方式 在讲解单点登录之前先讲解几个基本的概念: Cook ...

  9. vue,element列表大数据卡顿问题,vue列表渲染慢

    https://github.com/livelyPeng... 一个表格组件(完美解决万级数据渲染卡顿问题),流畅渲染万级数据并不会影响到el-table的原有功能 分析: 前端UI框架使用的是El ...

  10. 设计模式(九)Bridge模式

    Bridge模式就是将类的功能层次结构和类的实现层次结构连接起来. 类的功能层次结构就是根据实际非抽象类来说的,也就是父类具有基本功能,然后在子类中增加新功能.用于增加新功能. 类的实现层次结构就是根 ...