问题描述
试题编号: | 201712-1 |
试题名称: | 最小差值 |
时间限制: | 1.0s |
内存限制: | 256.0MB |
问题描述: | 问题描述 给定n个数,请找出其中相差(差的绝对值)最小的两个数,输出它们的差值的绝对值。 输入格式 输入第一行包含一个整数n。 输出格式 输出一个整数,表示答案。 样例输入 5 样例输出 1 样例说明 相差最小的两个数是5和4,它们之间的差值是1。 样例输入 5 样例输出 0 样例说明 有两个相同的数3,它们之间的差值是0. 数据规模和约定 对于所有评测用例,2 ≤ n ≤ 1000,每个给定的整数都是不超过10000的正整数。 |
很简单的题,博主给出3个版本
原版
#include<iostream>
#include<cmath>
using namespace std;
int main(){
int n;cin>>n;
int a[n];
for(int i=0;i<n;i++){
cin>>a[i];
}
for(int i=0;i<n-1;i++){
for(int j=0;j<n-1-i;j++){
if(a[j]>a[j+1]){
int temp=a[j];
a[j]=a[j+1];
a[j+1]=temp;
}
}
}
int min=abs(a[0]-a[1]);
for(int i=1;i<n-1;i++){
if(min>abs(a[i]-a[i+1])){
min=abs(a[i]-a[i+1]);
}
}
cout<<min;
}
//sort版
#include<iostream>
#include<cmath>
#include<algorithm>
using namespace std;
int main(){
int n;cin>>n;
int a[n];
for(int i=0;i<n;i++){
cin>>a[i];
}
sort(a,a+n);
int min=abs(a[0]-a[1]);
for(int i=1;i<n-1;i++){
if(min>abs(a[i]-a[i+1])){
min=abs(a[i]-a[i+1]);
}
}
cout<<min;
}
这里也是推荐大家学学sort很简单也很方便,只需要输入头和尾还有你需要的怎样的排序即可
//vector版
#include<bits/stdc++.h>
using namespace std;
int main(){
int n;cin>>n;
vector<int>a(n);
for(int i=0;i<n;i++){
cin>>a[i];
}
sort(a.begin(),a.end());
int min=abs(a[0]-a[1]);
for(int i=1;i<n-1;i++){
if(min>abs(a[i]-a[i+1])){
min=abs(a[i]-a[i+1]);
}
}
cout<<min;
}
这里推荐大家在CSP认证上直接写#include<bits/stdc++.h>,几乎是万能头文件,而且CSP是支持这个头文件的
还有就是这里vector的sort有所不一样,还请注意。