Помогите решить!!!
Пусть A=(a1,a2,…,an), B=(b1,b2,…,bm), C=(c1,c2,…,cp) – три конечные последовательности натуральных чисел. Допустим, что каждая отдельно взята последовательность упорядочена по возрастанию. Объедините три последовательности в одну последовательность D=(d1,d2,…,dn+m+p), являющуюся списком всех чисел из А, В, С, такую, что d1≤d2≤…≤dn+m+p.
Обязательным условием является то, что слияние должно быть выполнено за m+n+p действий, т.е. число сравнений должно быть не больше m+n+p.
Заранее благодарен.
Вот есть такой метод :
type
TArr = array[1..100] of integer;
procedure sliyanie(var Arr1,Arr2,Result:TArr; size1,size2:integer);
var
i,i1,i2,ny:integer;
begin
i1:=1; i2:=1;
ny:=0;
while(i1<=size1)and(i2<=size2) do begin
inc(ny);
if arr1[i1]<=arr2[i2] then begin
result[ny]:=arr1[i1];
inc(i1);
end
else begin
result[ny]:=arr2[i2];
inc(i2);
end;
end;
if i1<=size1 then
for i:=i1 to size1 do begin
inc(ny);
result[ny]:=arr1[i];
end
else
for i:=i2 to size2 do begin
inc(ny);
result[ny]:=arr2[i];
end;
end;
Попробуй поискать по форуму, по-моему, где-то это уже встречалось (можешь поискать сортировку слияниями)... Но сам алгоритм примерно такой:
Да, я уже заметил и покаялся выше
хотя по такому принципу можно довести до трех массивов я думаю.
Вот это я нашел на форуме:
Ну, и что не устраивает? Правда, потребовались незначительные изменения ... Вот проверка: частный случай (n = m = p = maxn)...
program sliyati_tri_mas;
const
maxn = 10;
type
arr_type = array[1..maxn+1] of integer;
const
a: arr_type = (2, 3, 4, 6, 8, 9, 11, 23, 25, 28, maxint);
b: arr_type = (5, 6, 7, 11, 12, 17, 19, 20, 21, 22, maxint);
c: arr_type = (15, 16, 17, 21, 22, 27, 29, 30, 31, 42, maxint);
function min(i, j: integer): integer;
begin
min := i; if j < i then min := j
end;
var
d: array[1..3*maxn]of integer;
ia,ib,ic,id:integer;
n,m,p:integer;
begin
n := maxn; m := maxn; p := maxn;
ia:=1; ib:=1; ic:=1; id:=0;
while id<n+m+p do begin
while (a[ia] <= min(b[ib], c[ic])) and (ia <= n) do begin
inc(id); d[id]:=a[ia]; inc(ia);
end;
while (b[ib] <= min(a[ia], c[ic])) and (ib <= m) do begin
inc(id); d[id]:=b[ib]; inc(ib);
end;
while (c[ic] <= min(a[ia], b[ib])) and (ic <= p) do begin
inc(id); d[id]:=c[ic]; inc(ic);
end;
end;
for id:=1 to n+m+p do
write(d[id],' ');
end.
А сравнений точно не будет больше 30?
Не уверен... Скорее всего будет больше... Но насколько я помню, нельзя сделать это за 30 сравнений. Ни один алгоритм сортировки не отсортирует тебе 30 элементов за 30 сравнений. Если уж на то пошло, то тебе надо просто "склеить" все массивы и пройтись по ним RadixSort-ом (http://forum.pascal.net.ru/index.php?showtopic=3065&view=findpost&p=32464), там по-моему элементы вообще не сравниваются.
Я наверно тебе уже надоел. Ноесли не сложно, можешь нарисовать блок-схему? Мне завтра прогу сдавать, а я в схемах не понимаю! Пожалуйста!!!!!!!!
Врялдли кто-то будет рисовать такую блок - схему, могу посоветовать только вот это : http://forum.pascal.net.ru/index.php?showtopic=4270