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;
Сортировка выдает удивительные вещи для разных размеров массива, хотя по идее должна выдавать одинаковые(как-бы логично): Ведь если(допустим массив отсортирован) посчитать количество таких (первых)
Что касается первых двух случаев (1, 1, 16129) и (1, 127, 127) - то время их выполнения не различается так, как ты показывал скриншотом. Не в 2 раза. Sorted: 249/235, Random: 486/470, Reverse:640/630, то есть, различия не такие критичные...
Что касается попытки проверить третий случай -
Insert p: 1 Insert m: 16129 Insert n: 1 No heap dump by heaptrc unit Exitcode = 201 Runtime error 201 at $0040F2F2 $0040F2F2 PCUBE_CREATE, line 58 of UCubServ.pas $0040CFBE CREATE, line 73 of UMenu.pas $0040D259 MENU, line 179 of UMenu.pas $00401567 main, line 7 of /kurs/main.pas $00408BD1