IPB
ЛогинПароль:

> Прочтите прежде чем задавать вопрос!

1. Заголовок темы должен быть информативным. В противном случае тема удаляется ...
2. Все тексты программ должны помещаться в теги [code=pas] ... [/code].
3. Прежде чем задавать вопрос, см. "FAQ", если там не нашли ответа, воспользуйтесь ПОИСКОМ, возможно такую задачу уже решали!
4. Не предлагайте свои решения на других языках, кроме Паскаля (исключение - только с согласия модератора).
5. НЕ используйте форум для личного общения, все что не относится к обсуждению темы - на PM!
6. Одна тема - один вопрос (задача)
7. Проверяйте программы перед тем, как разместить их на форуме!!!
8. Спрашивайте и отвечайте четко и по существу!!!

> Нужно отредактировать программу, Есть программа нужно исправить
Bart2000
сообщение 18.02.2012 0:44
Сообщение #1





Группа: Пользователи
Сообщений: 7
Пол: Мужской
Реальное имя: Даниил

Репутация: -  0  +


Условие: Есть n цветов разных видов. Составьте все возможные сочетания букетов из всех этих цветов. Количество цветов и их название вводит пользователь. Ввод вывод в текстовый файл.
Есть программа на она делает перестановку не со словами а с цифрами, надо поправит.
 type
mas=array [1..100] of integer;
var
n,i:integer;
a,p:mas;
procedure vivod(n:integer; var p:mas);
var i,j,imax:integer;
begin
imax:=1; {Определяем количество блоков в разбиении}
for i:=1 to n do
if p[i]>imax then imax:=p[i];
for i:=1 to imax do {Проходим по всем блокам данного разбиения}
begin
write('{'); {Выводим на экран i-й блок}
for j:=1 to n do {Просматриваем все элементы}
if p[j]=i then write(a[j],' '); {Если элемент принадлежит i-му блоку то выводим его на экран}
write('} ') {Блок напечатан}
end;
writeln; {Разбиение напечатано}
end;
procedure razb(i, j: integer); {i- рассматриваемый элемент}
var l: integer; {j- количество блоков в разбиении}
Begin {р - массив пометок, принадлежности к блоку разбиения}
if i>n then vivod(n, p) {Если рассматриваемый элемент больше, чем общее число элементов в множестве, то разбиение сформировано, выводим его}
else
for l := 1 to j do {Просматриваем все блоки}
begin
p[i] := l; {Ставим i-й элемент в l-й блок, l=1,..,j}
if l=j then razb(i+1, j+1) {Если i-й элемент вставили в последний блок, то переходим к следующему элементу i+1 и добавляем новый блок j+1}
else razb(i+1, j) {в противном случае переходим к следующему элементу i+1 не добавляя новый блок}
end;
end;
begin
writeln('Vvedite kol. el. v mnoj');
readln(n);
writeln('vvedite elementi mnoj');
for i:= 1 to n do
read(a[i]);
razb(1,1);
readln;

end.

 Оффлайн  Профиль  PM 
 К началу страницы 
+ Ответить 

Сообщений в этой теме


 Ответить  Открыть новую тему 
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0

 



- Текстовая версия 20.07.2025 2:26
Хостинг предоставлен компанией "Веб Сервис Центр" при поддержке компании "ДокЛаб"