1. Заголовок темы должен быть информативным. В противном случае тема удаляется ... 2. Все тексты программ должны помещаться в теги [code=pas] ... [/code], либо быть опубликованы на нашем PasteBin в режиме вечного хранения. 3. Прежде чем задавать вопрос, см. "FAQ", если там не нашли ответа, воспользуйтесь ПОИСКОМ, возможно такую задачу уже решали! 4. Не предлагайте свои решения на других языках, кроме Паскаля (исключение - только с согласия модератора). 5. НЕ используйте форум для личного общения, все что не относится к обсуждению темы - на PM! 6. Одна тема - один вопрос (задача) 7.Проверяйте программы перед тем, как разместить их на форуме!!! 8.Спрашивайте и отвечайте четко и по существу!!!
Упорядочить отдельно каждое сечение трехмерного массива А [p, m, n] насквозь по колонкам по неубыванию.
сортировка(Показать/Скрыть)
function PCube_SelectExchange2_byTruthIndex(var Cube: PCube; const p, m, n: word): longint; var B: MyType; i, ks, js, jt, kt: word; StartTime, FinishTime: TTime; Begin with StartTime do GetTime(Hours,Minutes,Seconds,HSeconds); for i := 1 to p do for ks := 1 to n do for js := 1 to m do begin for jt := js+1 to m do if Cube^[i]^[jt]^[ks] <= Cube^[i]^[js]^[ks] then begin b := Cube^[i]^[jt]^[ks]; Cube^[i]^[jt]^[ks] := Cube^[i]^[js]^[ks]; Cube^[i]^[js]^[ks] := b; end; for kt := ks+1 to n do for jt :=1 to m do if Cube^[i]^[jt]^[kt] <= Cube^[i]^[js]^[ks] then begin b := Cube^[i]^[jt]^[kt]; Cube^[i]^[jt]^[kt] := Cube^[i]^[js]^[ks]; Cube^[i]^[js]^[ks] := b; end; end; with FinishTime do GetTime(Hours,Minutes,Seconds,HSeconds); PCube_SelectExchange2_byTruthIndex := ResTime(StartTime, FinishTime); end;
Сортировка выдает удивительные вещи для разных размеров массива, хотя по идее должна выдавать одинаковые(как-бы логично): Ведь если(допустим массив отсортирован) посчитать количество таких (первых)