我想在C++中使用算法庫中的sort()。我可以找到排序向量只有的例子,因此我試圖通過初始化的數組初始化一個向量。執行時,我遇到了分段錯誤,無法找出我寫的代碼中出現了什麼問題。C++初始化數組初始化向量時的分段錯誤
#include <cmath>
#include <cstdio>
#include <vector>
#include <iostream>
#include <algorithm>
using namespace std;
int main() {
int n,k,packet[1000],min=0;
scanf("%d",&n);
scanf("%d",&k);
for (int i = 0; i < n; ++i)
{
scanf("%d",&packet[i]);
cout<<i<<endl;
}
cout<<"debug";
vector<int> packets(packet,packet+n);
vector<int>::iterator start,stop;
sort(packets.begin(),packets.begin()+n);
min=*(packets.begin())- *(packets.end());
cout<<min;
for (vector<int>::iterator it=packets.begin(); it!=packets.end()-k; ++it)
{
printf("%d ",*it);
if((*(it+k) - *it)<min)
{
start=it;
stop=it+k;
}
}
printf("%d\n",*stop- *start);
return 0;
}
你可以用'的std :: sort'有一個數組就好了。初始化矢量的相同迭代器是您傳遞給算法的東西。 – chris
編譯時如何得到分段錯誤? – Kunal
對於排序,請使用「sort(packets.begin(),packets.end());」如果這就是你的意思。 – kfsone