问题描述
试题编号: | 201409-1 |
试题名称: | 相邻数对 |
时间限制: | 1.0s |
内存限制: | 256.0MB |
问题描述: | 问题描述 给定n个不同的整数,问这些数中有多少对整数,它们的值正好相差1。 输入格式 输入的第一行包含一个整数n,表示给定整数的个数。 输出格式 输出一个整数,表示值正好相差1的数对的个数。 样例输入 6 样例输出 3 样例说明 值正好相差1的数对包括(2, 3), (6, 7), (7, 8)。 评测用例规模与约定 1<=n<=1000,给定的整数为不超过10000的非负整数。 |
答题栏
import java.util.Scanner;
public class Main {
public static void main(String[] args) {
Scanner s = new Scanner(System.in);
int N = s.nextInt();
int[] num = new int[N];
int i;
//输入N个数
for(i=0; i<N; i++) {
num[i] = s.nextInt();
}
new Main().Sort(num, N);
int counter=0;
for(i=0; i<N-1; i++) {
if(num[i]+1==num[i+1]) {//判断后一个数与前一个数相差 1
counter++;
}
}
System.out.print(counter);
}
//插入排序
public void Sort(int[] a, int n) {
int in, out;
for(out=1; out<n; out++) {
int temp = a[out];
in = out;
while(in>0 && a[in-1] >= temp) {
a[in] = a[in-1];
--in;
}
a[in] = temp;
}
}
}