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

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

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

> сортировка
dmx
сообщение 17.12.2005 19:31
Сообщение #1


Гость






Рассмотрим алгоритм сортировки пузырьком.

var
a : array [1..50000] of integer;
n, b, i, k, j, x, t : integer;
loopCnt : integer;
begin
read(n);
for i := 1 to n do read(a[i]);

loopCnt := 0;

b := n;
while b > 0 do begin
inc(loopCnt);
t := 0;
for j := 1 to b - 1 do
if a[j] > a[j + 1] then begin
x := a[j];
a[j] := a[j + 1];
a[j + 1] := x;
t := j;
end;
b := t;
end;

for i := 1 to n do
write(a[i], ' ');
end.


Вам задана перестановка, которая подается на вход этого алгоритма сортировки. Найдите значение переменной loopCnt после выполнения алгоритма.


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

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

Пример

Ввод

5
1 4 3 5 2


Вывод

4


при том
ограничение времени на тест: 1 сек.
ограничение памяти на тест: 4096 KB.

вывести loopcnt просто по окончанию программы не проходит по времени.

Сообщение отредактировано: volvo - 6.11.2006 16:25
 К началу страницы 
+ Ответить 

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


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

 



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