VBA, нужно помощь в преодолении ошибки Subscript out of range, error 9

проблема excel VBA office програмирование

Есть код, выдает вышеуказанную ошибку. Убиранием конструкции Do...Loop он работает без ошибок(но соответственно не сортирует.
Что нужно сделать, что бы код заработал.Моя реализация: из одномерного массива, некого размера, брались элементы и заносились в массив. Далее шла сортировка от большего к меньшему( первый наибольший,второй меньший и т.д.). Из отсортированного массива выбралось наибольшее значение которое будет равно трем. По сути его и нужно было найти среди всего массива.


Option Base 1
Public Sub rgr2()
Dim a() As Integer, i As Integer, r As Integer, m As Integer
Dim fl As Double, c As Double, n As Integer

n = Val(InputBox("Введите значение количества элементов", "Окно ввода", "10"))
ReDim Preserve a(n) As Integer
m = 3

For i = 1 To n
a(i) = Cells(i, 1)
Next i

Do
fl = 0
For i = 1 To n
If a(i) < a(i + 1) Then
r = a(i)
a(i) = a(i + 1)
a(i + 1) = r
fl = fl + 1
End If
Next i
Loop While fl > 0

Debug.Print "Отсортировалось по макс."
For i = 1 To n
Debug.Print a(i);
Next i

For i = 1 To n
If a(i) / m = Int(a(i) / m) Then Debug.Print "#"; i; ""; a(i)
Next i

For i = 1 To n
a(i) = Cells(i, 3)
Next i

End Sub
Ответы:
Do
fl = 0
  For i = 1 To n
      If a(i) < a(i + 1) Then
      r = a(i)
      a(i) = a(i + 1)
      a(i + 1) = r
      fl = fl + 1
      End If
  Next i
Loop While fl > 0


11 лет назад

RPI.su - самая большая русскоязычная база вопросов и ответов. Наш проект был реализован как продолжение популярного сервиса otvety.google.ru, который был закрыт и удален 30 апреля 2015 года. Мы решили воскресить полезный сервис Ответы Гугл, чтобы любой человек смог публично узнать ответ на свой вопрос у интернет сообщества.

Все вопросы, добавленные на сайт ответов Google, мы скопировали и сохранили здесь. Имена старых пользователей также отображены в том виде, в котором они существовали ранее. Только нужно заново пройти регистрацию, чтобы иметь возможность задавать вопросы, или отвечать другим.

Чтобы связаться с нами по любому вопросу О САЙТЕ (реклама, сотрудничество, отзыв о сервисе), пишите на почту [email protected]. Только все общие вопросы размещайте на сайте, на них ответ по почте не предоставляется.