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

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

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

> помогите решить задачу., задача на метод выбора.
Fatality
сообщение 28.03.2007 14:39
Сообщение #1





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

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


Искал задачу в FAQ но не нашел.
Если кто знает как решать решите очень надо.
Дан массив натуральных чисел. Упорядочить его элементы методом выбора по убыванию наибольшего простого делителя.
 Оффлайн  Профиль  PM 
 К началу страницы 
+ Ответить 
 
 Ответить  Открыть новую тему 
Ответов
volvo
сообщение 28.03.2007 14:52
Сообщение #2


Гость






Метод простого выбора - это "Пузырек", он в FAQ-е описывается... А что надо добавить:


Function GetMaxSimpleDivider(X: Integer): Integer;
Begin
... { Тут находишь наибольший простой делитель числа X }
End;

...
For i := 1 To n Do
For j := n DownTo i+1 Do
{ Не просто сравнивать 2 элемента, а сравнивать результат функции }
If GetMaxSimpleDivider(ar[Pred(j)]) < GetMaxSimpleDivider(ar[j]) Then Begin
T := ar[Pred(j)]; ar[Pred(j)] := ar[j]; ar[j] := T
End

( определение простоты чисел - здесь: Замечательные числа )
 К началу страницы 
+ Ответить 

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


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

 



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