Студопедия

КАТЕГОРИИ:


Архитектура-(3434)Астрономия-(809)Биология-(7483)Биотехнологии-(1457)Военное дело-(14632)Высокие технологии-(1363)География-(913)Геология-(1438)Государство-(451)Демография-(1065)Дом-(47672)Журналистика и СМИ-(912)Изобретательство-(14524)Иностранные языки-(4268)Информатика-(17799)Искусство-(1338)История-(13644)Компьютеры-(11121)Косметика-(55)Кулинария-(373)Культура-(8427)Лингвистика-(374)Литература-(1642)Маркетинг-(23702)Математика-(16968)Машиностроение-(1700)Медицина-(12668)Менеджмент-(24684)Механика-(15423)Науковедение-(506)Образование-(11852)Охрана труда-(3308)Педагогика-(5571)Полиграфия-(1312)Политика-(7869)Право-(5454)Приборостроение-(1369)Программирование-(2801)Производство-(97182)Промышленность-(8706)Психология-(18388)Религия-(3217)Связь-(10668)Сельское хозяйство-(299)Социология-(6455)Спорт-(42831)Строительство-(4793)Торговля-(5050)Транспорт-(2929)Туризм-(1568)Физика-(3942)Философия-(17015)Финансы-(26596)Химия-(22929)Экология-(12095)Экономика-(9961)Электроника-(8441)Электротехника-(4623)Энергетика-(12629)Юриспруденция-(1492)Ядерная техника-(1748)

Пример. Пример 1. Найти сумму первых 50 чисел натурального ряда. Dim i, s As Integer s = 0 For I = 1 To 50 s = s + I Next




Пример.

Пример 2.

Пример 1.

Найти сумму первых 50 чисел натурального ряда. Dim i, s As Integer s = 0 For I = 1 To 50 s = s + I Next

 

В массив M2 внесена информация. Обработать N элементов и найти сумму значений четных элементов массива. При достижении заданного число SK выйти из цикла досрочно. Dim i, S,N As Integer Dim M2(200) As Integer … S = 0 For I = 2 To N Step 2 S=S+M2(i) If S >=SK Then Exit For Next

 

Особый интерес представляют комбинированные алгоритмы, в которых одновременно используются алгоритмы цикла и ветвления.

 

В ячейки А1:А33 внесена информация. В какой строке содержится максимальное значение и чему оно равно.

 

N = 1: mx = Cells(1, 1) For k = 2 To 33 If Cells(k, 1) > mx Then N = k: mx = Cells(k, 1) End If Next k Cells(1, 2) = N: Cells(2, 2) = mx 'Значение первой строки – условный Max. 'Цикл начинается со 2 строки. 'Если элемент превышает условный 'Max, он принимается как новый Max. 'Конец проверки. ' Конец цикла. 'Вывод результатов.

 

Отступы слева при наборе операторов применены для улучшения восприятия логики программы. VBA их не требует, ни и не опротестовывает.

При организации вложенных циклов For...Next (один цикл For...Next располагается внутри другого). Счетчик каждого цикла должен иметь уникальное имя. Допускаются следующие конструкции:

For I = 1 To 10

For J = 1 To 10

For K = 1 To 10

...

Next K

Next J

Next I

 

Выполнить сортировку элементов массива М1(N) методом пузырька.

Суть метода: при поочередном сравнении каждой пары элементов массива они меняются местами, если стоят в неправильном (несортированном) виде (рис. 11.12). В результате одного цикла прохода по массиву самый маленький элемент оказывается в конце массива (для остальных элементов сортировка может выполниться лишь частично. Далее указанный процесс повторяется вновь и вновь, пока все данные не упорядочатся.

Рис. 11.12. Схема проведения сортировки.

N = 10 … For j = 1 To N – 1 For i = 1 To N - j If M1(i) > M1(i + 1) Then X = M1(i) M1(i) = M1(i + 1) M1(i + 1) = X End If Next i Next j     ' Кол-во прогонов на 1 меньше числа элементов. ' Уже отсортированные элементы не берутся. 'Неправильная последовательность. 'Обмен через дополнительную переменную.   'Конец обмена. 'Конец прогона.

 

Теперь Вы сможете оценить, какие удобства предоставляет пользователям MS Excel, в котором для проведения сортировки Вам было достаточно нажать кнопку .

 

Команда While – предназначена для организации циклов, в которых ведется повторение набора команд, пока соблюдается некоторое условие.

Синтаксис команды допускает варианта ее применения.

1 вариант 2 вариант
Do While <условие> <набор команд> [Exit Do] Loop While <условие> <набор команд> [Exit Do] Wend

 

В любом варианте набор команд, определяющих тело цикла, повторяется до тех пор, пока выполняется заданное в первой строке цикла условие.

Инструкции [ Exit Do ] не обязательны и применяются для экстренного выхода из цикла до достижения его конца (число таких альтернативных способов выхода из цикла не ограничено). Инструкция Exit Do часто применяется вместе с проверкой некоторого условия (например, If...Then). Эта инструкция передает управление команде, непосредственно следующей за командой Loop ( или Wend).

Обратите внимание, что циклы While берут на себя труд проверять ЛЮБОЕ сложное условие выхода из цикла, чего не было в циклах For, но не заботятся ни о каких счетчиках, а значит, об изменении номера текущего элемента массива или строки электронной таблицы должны позаботиться Вы!

 




Поделиться с друзьями:


Дата добавления: 2015-04-24; Просмотров: 558; Нарушение авторских прав?; Мы поможем в написании вашей работы!


Нам важно ваше мнение! Был ли полезен опубликованный материал? Да | Нет



studopedia.su - Студопедия (2013 - 2024) год. Все материалы представленные на сайте исключительно с целью ознакомления читателями и не преследуют коммерческих целей или нарушение авторских прав! Последнее добавление




Генерация страницы за: 0.01 сек.