题目描述
给定 n 个不同的整数,问这些数中有多少对整数,它们的值正好相差 1。
输出格式
输入的第一行包含一个整数 n,表示给定整数的个数。
第二行包含所给定的 n 个整数。
输出格式
输出一个整数,表示值正好相差 1 的数对的个数。
数据范围
1≤n≤1000,
给定的整数为不超过 10000 的非负整数。
输入样例:
6
10 2 6 3 7 8
输出样例:
3
样例解释
值正好相差 1 的数对包括 (2,3),(6,7),(7,8)。
思路
我们可以先将整个数列进行排序,因为差值是1的两个整数一定是相邻的两个整数(因为每个数都不一样)
代码$O(nlogn)$
#include<iostream>
#include<algorithm>
using namespace std;
const int N=1010;
int n;
int q[N];
int main()
{
cin>>n;
for(int i=0;i<n;i++)
{
cin>>q[i];
}
sort(q,q+n);
int res=0;
for(int i=1;i<n;i++)
{
if(q[i]-q[i-1]==1)
res++;
}
cout<<res;
return 0;
}