1. Заголовок темы должен быть информативным. В противном случае тема удаляется ...
2. Все тексты программ должны помещаться в теги [code=pas] ... [/code], либо быть опубликованы на нашем PasteBin в режиме вечного хранения.
3. Прежде чем задавать вопрос, см. "FAQ", если там не нашли ответа, воспользуйтесь ПОИСКОМ, возможно такую задачу уже решали!
4. Не предлагайте свои решения на других языках, кроме Паскаля (исключение - только с согласия модератора).
5. НЕ используйте форум для личного общения, все что не относится к обсуждению темы - на PM!
6. Одна тема - один вопрос (задача)
7. Проверяйте программы перед тем, как разместить их на форуме!!!
8. Спрашивайте и отвечайте четко и по существу!!!
| SANCTUS |
Сообщение
#1
|
|
Группа: Пользователи Сообщений: 4 Пол: Мужской Репутация: 0 |
Помогите решить!!!
Пусть 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. Заранее благодарен. |
![]() ![]() |
| klem4 |
Сообщение
#2
|
![]() Perl. Just code it! ![]() ![]() ![]() ![]() ![]() ![]() Группа: Пользователи Сообщений: 4 100 Пол: Мужской Реальное имя: Андрей Репутация: 44 |
Да, я уже заметил и покаялся выше
хотя по такому принципу можно довести до трех массивов я думаю. Сообщение отредактировано: klem4 - -------------------- perl -e 'print for (map{chr(hex)}("4861707079204E6577205965617221"=~/(.{2})/g)), "\n";'
|
| SANCTUS |
Сообщение
#3
|
|
Группа: Пользователи Сообщений: 4 Пол: Мужской Репутация: 0 |
Вот это я нашел на форуме:
Код program sliyati_tri_mas; const maxn=1000; var a,b,c:array[1..maxn+1]of integer; d:array[1..3*maxn]of integer; ia,ib,ic,id:integer; n,m,p:integer; begin read(n); for ia:=1 to n do read(a[ia]); a[n+1]:=maxint; read(m); for ib:=1 to m do read(b[ib]); b[m+1]:=maxint; read(p); for ic:=1 to p do read(c[ic]); c[p+1]:=maxint; ia:=1; ib:=1; ic:=1; id:=0; while id<n+m+p do begin if a[ia]<b[ib] then begin if a[ia]<c[ic] then begin inc(id); d[id]:=a[ia]; inc(ia); end else begin inc(id); d[id]:=c[ic]; inc(ic); end; end else begin if b[ib]<c[ic] then begin inc(id); d[id]:=b[ib]; inc(ib); end else begin inc(id); d[id]:=c[ic]; inc(ic); end; end; end; for id:=1 to n+m+p do write(d[id],' '); end. Я пробовал "вручную" выполнять эту программу. У меня вроде бы не получилось m+n+p сравнений. Может быть я неправильно делал? Попробуйте сами! Тегами [CОDE] пользуемся ... Сообщение отредактировано: volvo - |
SANCTUS Три последовательности. 5.07.2005 17:17
klem4 Вот есть такой метод :
type
TArr = array[1.… 5.07.2005 17:31
volvo Попробуй поискать по форуму, по-моему, где-то это … 5.07.2005 17:37
volvo Ну, и что не устраивает? Правда, потребовались нез… 5.07.2005 18:33
SANCTUS А сравнений точно не будет больше 30? 5.07.2005 19:13
volvo Не уверен... Скорее всего будет больше... Но наско… 5.07.2005 19:25
SANCTUS Я наверно тебе уже надоел. Ноесли не сложно, можеш… 5.07.2005 19:57
klem4 Врялдли кто-то будет рисовать такую блок - схему, … 5.07.2005 20:45![]() ![]() |
|
Текстовая версия | 28.12.2025 19:03 |