2015-10-04 6 views
0

Я действительно новичок в C++. Я знаю, что это может быть из-за неправильное распределение памяти, но я попытался запустить линии, указывающие ошибки только и не нашел ничего плохого ...libC++ abi.dylib: завершение с неперехваченным исключением типа std :: length_error: vector

Функции с частью ошибки (т является 1211200 * 7 массива):

vector<double>tmp; 
vector<size_t>tmpsort; 
long ctmp=1000000,c=570404,l=1211200,indt=0; 
double** m = new double*[ctmp]; 
for(int i = 0; i < ctmp; ++i) 
    m[i] = new double[7]; 
    double** mt = new double*[c]; 
    for(int i = 0; i < c; ++i) 
     mt[i] = new double[7]; 
for (int i=0; i<l; i++) { 
    if (t[i][0]!=0&&t[i][1]!=0) { 
     mt[indt][0]=t[i][0]; 
     mt[indt][1]=t[i][1]; 
     mt[indt][2]=t[i][2]; 
     mt[indt][3]=t[i][3]; 
     mt[indt][4]=t[i][4]; 
     mt[indt][5]=t[i][5]; 
     mt[indt][6]=t[i][6]; 
     indt++; 
    } 
} 
for (int i=0; i<c; i++) { 
    tmp.push_back(pow(pow(distanceEarth(mt[i][1], mt[i][0], d[1], d[0]),2)+pow(mt[i][2]-d[2],2),0.5)); 
} 
    tmpsort.assign(ordered(tmp).begin(), ordered(tmp).end());//signal SIGABRT 
    for (int i=0; i<1000; i++) { 
     m[i][0]=mt[tmpsort[i]][0]; 
     m[i][1]=mt[tmpsort[i]][1]; 
     m[i][2]=mt[tmpsort[i]][2]; 
     m[i][3]=mt[tmpsort[i]][3]; 
     m[i][4]=mt[tmpsort[i]][4]; 
     m[i][5]=mt[tmpsort[i]][5]; 
     m[i][6]=mt[tmpsort[i]][6]; 
    } 
    c=1000; 

Для получения упорядоченного (от c++ sort keeping track of indices):

template <typename T> 
vector<size_t> ordered(vector<T> const& values) { 
vector<size_t> indices(values.size()); 
iota(begin(indices), end(indices), static_cast<size_t>(0)); 

sort(begin(indices), end(indices),[&](size_t a, size_t b) { return values[a] < values[b];}); 
return indices; 
} 

Для distanceEarth (функцию, которая может возвращать расстояние между двумя точками):

double deg2rad(double deg) { 
return (deg * M_PI/180);} 
double rad2deg(double rad) { 
return (rad * 180/M_PI);} 
double distanceEarth(double lat1d, double lon1d, double lat2d, double lon2d) { 
double lat1r, lon1r, lat2r, lon2r, u, v; 
lat1r = deg2rad(lat1d); 
lon1r = deg2rad(lon1d); 
lat2r = deg2rad(lat2d); 
lon2r = deg2rad(lon2d); 
u = sin((lat2r - lat1r)/2); 
v = sin((lon2r - lon1r)/2); 
return 2.0 * earthRadiusKm * asin(sqrt(u * u + cos(lat1r) * cos(lat2r) * v * v));} 

Терминал показывает сообщение об ошибке как заголовок. Может ли кто-нибудь предложить мне, что проверить дальше? Благодаря!

ответ

2

У вас есть проблема здесь:

tmpsort.assign(ordered(tmp).begin(), ordered(tmp).end());//signal SIGABRT 

Функция возвращает ordered по значению. Это означает, что для разных временных векторов вызывается begin() и end().

+0

Спасибо. Могу ли я спросить, как я могу назначить упорядоченный (tmp) tmpsort? Функция не является основной функцией, поэтому я не могу использовать «=» здесь ... – dinex

+0

Оба они кажутся «vector », поэтому простое назначение должно работать. –

+0

Xcode предполагает, что «нет жизнеспособных перегруженных» = «». Вместо этого я использую push_back, и он успешно работает. – dinex

Смежные вопросы