Отправляет email-рассылки с помощью сервиса Sendsay
  Все выпуски  

RFpro.ru: Программирование на Basic / VBA


Хостинг портала RFpro.ru:
Московский хостер
Профессиональный платный хостинг на базе Windows 2008

РАССЫЛКИ ПОРТАЛА RFPRO.RU

Чемпионы рейтинга экспертов в этой рассылке

Гаряка Асмик
Статус: Специалист
Рейтинг: 2926
∙ повысить рейтинг »
Vasiliy83
Статус: Бакалавр
Рейтинг: 1406
∙ повысить рейтинг »
Megaloman
Статус: Профессионал
Рейтинг: 1130
∙ повысить рейтинг »

/ КОМПЬЮТЕРЫ И ПО / Программирование / Basic/VBA

Номер выпуска:999
Дата выхода:20.03.2010, 20:30
Администратор рассылки:Калашников О.А., Руководитель
Подписчиков / экспертов:347 / 99
Вопросов / ответов:1 / 1

Вопрос № 177257: Уважаемые эксперты подскажите в следующем имеется массив, как в нём упорядочить записи согласно алфавита. Спасибо Эндрю ...



Вопрос № 177257:


Уважаемые эксперты подскажите в следующем имеется массив, как в нём упорядочить записи согласно алфавита. Спасибо Эндрю

Отправлен: 14.03.2010, 23:16
Вопрос задал: Ципихович Эндрю, Посетитель
Всего ответов: 1
Страница вопроса »


Отвечает Megaloman, Профессионал :
Здравствуйте, Ципихович Эндрю.
Вот пример кода с сортировкой. Для примера приведены два массива. Решение чувствительно к регистру букв (Прописные - строчные)
Код:

' ---------------------------------------------- Пример 1
N = 5 ' Число элементов массива
ReDim Mass(1 To N)

Mass(1) = "Варкалось"
Mass(2) = "Хливкие шорьки"
Mass(3) = "Пырялись по наве"
Mass(4) = "И хрюкотали зелюки"
Mass(5) = "Как мюмзики в мове"

' --------------------------------- Сортировка
For i = 1 To N
For j = i To N
If Mass(i) > Mass(j) Then
sss = Mass(j)
Mass(j) = Mass(i)
Mass(i) = sss
End If
Next
Next

' --------------------------------- Выдача в MsgBox

sss = ""
For i = 1 To N
sss = sss + Mass(i) + vbCrLf
Next
MsgBox sss


' ---------------------------------------------- Пример 2
N = 5
ReDim Mass(1 To N)

Mass(1) = "ав"
Mass(2) = "адбмбвг"
Mass(3) = "адбахххх"
Mass(4) = "абвгд"
Mass(5) = "абв"

' --------------------------------- Сортировка
For i = 1 To N
For j = i To N
If Mass(i) > Mass(j) Then
sss = Mass(j)
Mass(j) = Mass(i)
Mass(i) = sss
End If
Next
Next

' --------------------------------- Выдача в MsgBox

sss = ""
For i = 1 To N
sss = sss + Mass(i) + vbCrLf
Next
MsgBox sss

А вот решение нечувствительное к регистру букв (Прописные - строчные) (тол ько фрагмент собственно сортировки)
Код:
' --------------------------------- Сортировка
For i = 1 To N
For j = i To N
If UCase(Mass(i)) > UCase(Mass(j)) Then
sss = Mass(j)
Mass(j) = Mass(i)
Mass(i) = sss
End If
Next
Next

-----
Нет времени на медленные танцы

Ответ отправил: Megaloman, Профессионал
Ответ отправлен: 15.03.2010, 18:17
Номер ответа: 260141

Оценка ответа: 5

Вам помог ответ? Пожалуйста, поблагодарите эксперта за это!
Как сказать этому эксперту "спасибо"?
  • Отправить SMS #thank 260141 на номер 1151 (Россия) | Еще номера »
  • Отправить WebMoney:

  • Оценить выпуск »
    Нам очень важно Ваше мнение об этом выпуске рассылки!

    Задать вопрос экспертам этой рассылки »

    Скажите "спасибо" эксперту, который помог Вам!

    Отправьте СМС-сообщение с тестом #thank НОМЕР_ОТВЕТА
    на короткий номер 1151 (Россия)

    Номер ответа и конкретный текст СМС указан внизу каждого ответа.

    Полный список номеров »

    * Стоимость одного СМС-сообщения от 7.15 руб. и зависит от оператора сотовой связи. (полный список тарифов)
    ** При ошибочном вводе номера ответа или текста #thank услуга считается оказанной, денежные средства не возвращаются.
    *** Сумма выплаты эксперту-автору ответа расчитывается из суммы перечислений на портал от биллинговой компании.


    © 2001-2010, Портал RFpro.ru, Россия
    Авторское право: ООО "Мастер-Эксперт Про"
    Автор: Калашников О.А. | Программирование: Гладенюк А.Г.
    Хостинг: Компания "Московский хостер"
    Версия системы: 2010.6.14 от 03.03.2010

    В избранное