50 за подробное ! в программе описан одномерный целочисленных массива a с индексами от 1 до 10. ниже представлен фрагмент программы, записанный на разных языках программирования, в котором значения элементов сначала , а затем меняются. сколько элементов массива будут нечетными? бейсик for i=1 to 10 a(i)=5+i next i for i=1 to 10 if (a(i)+i > 12) then a(i)=a(i)+ i endif next i
FOR i=1 TO 10
A(i)=5+i
NEXT i
Здесь в цикле для i, меняющегося от 1 до 10, в массив А помещаются значения i+5, т.е. 6, 7, 8, .. 15.
FOR i=1 TO 10
IF (A(i)+i >12) THEN
A(i)=A(i)+ i
ENDIF
NEXT i
В этом цикле i также меняется от 1 до 10. Для всех значений элементов массива, которые в сумме со своим порядковым номером в массиве (индексом) превысят 12, значение элемента будет увеличено на этот номер.
a[1]+1=6+1=7. Это число меньше 12 и a[1] остается прежним. Так же, a[2]+2=9, a[3]+3=11 и они тоже не изменятся. Начиная с a]4]+4=13 значения будут изменяться на новые и в результате мы получим семь новых значений: 13, 15, 17,... 25. Все они будут нечетными. И еще одно нечетное значение (7) имеет a[2]. Итого, нечетные значения будут иметь 8 элементов.
Итак, результаты циклов:
1-вый цикл:
5+1=6
5+2=7
5+3=8
5+4=9
5+5=10
5+6=11
5+7=12
5+8=13
5+9=14
5+10=15
2-ой цикл:
6+1=7
7+2=9
8+3=11
9+4=13
10+5=15
11+6=17
12+7=19
13+8=21
14+9=23
15+10=25
Ну и теперь смотрим, какие результаты из второго цикла больше 12: все кроме 7, 9 и 11.
Отбрасываем их и смотрим, какие из чисел нечётные: все оставшиеся результаты нечетные, а всего их 7 и элемент A[2] имеет значение 7, значит его тоже считаем, следовательно - ответ: 8 элементов будут нечетными.