题目
总结:
1、题目隐晦描述升序输出,那么就需要先对数组进行排序:sort(arr.begin(),sort.end())
2、数组的长度不能用sizeof求,直接arr.size()就求出了数组的长度
3、定义新数组时需要看头文件的定义,本函数体第一行定义arr数组时,是:vector<vector>,那在定义新数组时也需要这样
4、在数组中插入新值时,可直接用arr1.emplace_back(vector{arr[i],arr[i+1]}); 中的emplace_back函数直接引入。如果用push_back的话,需要先将数据从函数中读到一个常量中,再输入数组。
class Solution {
public:
vector<vector<int>> minimumAbsDifference(vector<int>& arr) {
int temp=abs(arr[0]-arr[1]);
int a;
vector<vector<int>> arr1;
sort(arr.begin(),arr.end());
for(int i=0;i<arr.size()-1;i++)
{
a = abs(arr[i]-arr[i+1]);
if(temp>a)
{
arr1={{arr[i],arr[i+1]}};
temp=a;
}
else if(temp==a)
{
arr1.emplace_back(vector<int>{arr[i],arr[i+1]});
}
else{
continue;
}
}
return arr1;
}
};