В
Все
М
Математика
А
Английский язык
Х
Химия
Э
Экономика
П
Право
И
Информатика
У
Українська мова
Қ
Қазақ тiлi
О
ОБЖ
Н
Немецкий язык
Б
Беларуская мова
У
Українська література
М
Музыка
П
Психология
А
Алгебра
Л
Литература
Б
Биология
М
МХК
О
Окружающий мир
О
Обществознание
И
История
Г
Геометрия
Ф
Французский язык
Ф
Физика
Д
Другие предметы
Р
Русский язык
Г
География

найти дополнительный код числа n, которое находится в к-ичной системе счисления, и проверить его правильность:
1)n=-976; k=3
2)n=-5729184; k=15
3)n=-338860; k=12
4)n=-928812; k=10
5)n=-1452167; k=11
6)n=-2578; k=4

Показать ответ
Ответ:
Shamsudi95
Shamsudi95
29.08.2021 16:25

Давай сначала кратко изложу суть решения, а затем уже разберемся более детально. В коде имеется 2 процедуры, процедура Nermucum считывает с клавиатуры n чисел, а затем выводит эти числа. Процедура Artacum выводит элементы массива на экран. (зачем так сделано и почему такой страшный нейминг вопрос не ко мне). В основной программе массив меняет местами четные элементы.

Теперь пробежимся по коду:

Program kursayin_khndir_1;

Type arr = array [1..100] of integer;

var a: arr; mp: integer;

n,i,j,k: integer;

Здесь мы имеем:  имя программы - kursayin_khndir_1, тип arr, который представляет собой массив целых чисел из 100 элементов, переменную a с типом arr( то есть массив), переменную mp целого типа, также переменные n, i, j, k целого типа.

procedure Nermucum(var a: arr);

var i:integer;

begin;

for i:= 1 to n do

begin ;

read(a[i]);

end;

for i:= 1 to n do

write(a[i]:5);

writeln;

end;

Первая процедура, которая принимает аргумент типа arr, функция нам считать элементы с клавиатуры(с 1-го цикла), а затем вывести эти элементы (с второго цикла).

procedure Artacum(var arr_1: arr);

var i:integer;

begin

for i:= 1 to n do write(arr_1[i]:5);

end;

Вторая процедура, также принимает аргумент типа arr, она просто выводит значения элементов массива на экран.

Основную программу разделим на части.

readln(n);

Nermucum(a);

i:=1;

j:=n;

Считываем число n(количество элементов массива)

Вызываем процедуру Nermucum, которая считает элементы массива с клавиатуры и выведет нам массив на экран.

Даем переменной i значение 1, а переменной j значение n. То есть, i будет указывать на начало массива, а j на конец массива.

Смотрим основной цикл, который тут используется:

while i<=j do

   if a[i] mod 2=0 then

       begin

        if (a[j] mod 2=0)and(i<>j) then

             begin

                mp:=a[i]; a[i]:=a[j]; a[j]:=mp;

                  i:=i+1; j:=j-1;

              end

       else j:=j-1;

     end

  else i:=i+1;

Начиная с 1 элементы функция ищет чётный элемент, если она его находит, то проверяет условие: a[j] четный и не равен i, если условие выполняется, то мы меняем местами i-тый и j-тый элемент, затем сдвигаем наши "указатели" на начало и конец на 1 элемент, если же условия не выполнилось, то никакой замены не производим, однако, "указатели" на начало и конец всё равно сдвигаем.

Artacum(a);

Ну и в конце вызываем процедуру Artacum, чтобы вывести наш массив на экран.

Если остались вопросы - добро в комментарии.

0,0(0 оценок)
Ответ:
БеняФазбер
БеняФазбер
17.02.2022 12:12

6*s*s*s*s*s > 800*s*s*s

s*s*s*s*s = s^{5}

s*s*s =  s^{3}

Заменим s на x;

Цикл прервется когда выполнится условие 6*s*s*s*s*s < 800*s*s*s

6x^{5} < 800x^{3} \\3x^{5} < 400x^{3} \\3x^{3} < 400x\\3x^{3} - 400x < 0\\x(3x^{2} - 400) < 0\\

x∈(-∞, 20/√3) ∪ (0, 20/√3)

Нас интересуют только отрицательные значения т.к. переменная s =-1 и в цикле она уменьшается.

Граничное значение \frac{-20}{\sqrt{3} } ≈- 11,54

Посмотрим на переменную s:

1-я итерация цикла s=-1

2-я итерация цикла s=-3

3-я итерация цикла s=-5

4-я итерация цикла s=-7

5-я итерация цикла s=-9

6-я итерация цикла s=-11

Цикл продолжится т.к. граничное значение -11,54 > 11.

7-я итерация цикла s=-13. цикл завершается.

Всего 6 итераций.

посмотрим на n:

n=3 и каждую итерацию

увеличивается на 2 => нужно вычислить 7-й член геометрической прогрессии(7 т.к. цикл выполнился 6 раз + n = 3 - 1-й член прогрессии):

xₙ = x₁ * qⁿ ⁻ ¹; q = 2(каждую итерацию увеличение на 2)

x₆ = 3 * 2⁷ ⁻ ¹ = 3 * 2⁶ = 3 * 64 = 192.

n - s = 192 - (-13) = 192 + 13 = 205.

0,0(0 оценок)
Популярные вопросы: Информатика
Полный доступ
Позволит учиться лучше и быстрее. Неограниченный доступ к базе и ответам от экспертов и ai-bota Оформи подписку
logo
Начни делиться знаниями
Вход Регистрация
Что ты хочешь узнать?
Спроси ai-бота