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

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

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

> Перестановки
gamordzhoba
сообщение 1.12.2005 21:36
Сообщение #1


Гость






Дана перестановка. Наименьшее число обменов, чтобы ее отсортировать.

Входные данные
Число N (1 <= N <= 10000), затем перестановка.

Выходные данные
Выведите ответ.

Пример

Ввод

5
1 4 3 5 2


Вывод

2

Что то не получается.
 К началу страницы 
+ Ответить 
 
 Ответить  Открыть новую тему 
Ответов
roma
сообщение 3.12.2005 23:59
Сообщение #2


Гость






Вот недавно делал похожую прогу, вот что из нее получилось:

var
mas:array[1..100000] of longint;
c:array [1..100000] of boolean;
k,sum,d,i,n:integer;

begin
ReadLn(N);
for i:=1 to N do
begin
Read(k);
mas[k]:=i;
end;
sum:=0;
i:=1;
repeat
while (c[i]) and (i<=n) do inc(i);
if i>n then break else c[i]:=true;
k:=mas[i];
c[k]:=true;
d:=1;
while i<>k do
begin
inc(d);
c[k]:=true;
k:=mas[k];
end;
sum:=sum+d-1;
until false;
Writeln(sum);
end.

 К началу страницы 
+ Ответить 

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


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

 



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