М
Молодежь
К
Компьютеры-и-электроника
Д
Дом-и-сад
С
Стиль-и-уход-за-собой
П
Праздники-и-традиции
Т
Транспорт
П
Путешествия
С
Семейная-жизнь
Ф
Философия-и-религия
Б
Без категории
М
Мир-работы
Х
Хобби-и-рукоделие
И
Искусство-и-развлечения
В
Взаимоотношения
З
Здоровье
К
Кулинария-и-гостеприимство
Ф
Финансы-и-бизнес
П
Питомцы-и-животные
О
Образование
О
Образование-и-коммуникации
jeon200
jeon200
05.01.2022 19:20 •  Информатика

Написать программу, которая вводит n элементов массива и вычисляет сумму первого и максимального элемента массива

👇
Ответ:

Случайным образом вводятся целые числа от 0 до 999.
max - максимальный элемент массива
i - цикловая переменная.

var
a : array [1..100] of integer;
max, i, n : integer;
begin
readln (n);
for i := 1 to n do
a [ i ] := random (1000);
max :=  a [ 1 ];
for i := 2 to n do
if a [ i ] > max then
max :=  a [ i ];
writeln (max + a [ 1 ])
end.

4,7(61 оценок)
Ответ:
misterpordon
misterpordon
05.01.2022

uses crt;

var
  a:array [1..1000] of integer;
  max,i,k:integer;
begin
  write('Введи количество элементов массива: '); read(k);
  for i:=1 to k do
  begin
    a[i]:=random(100)-50;
    write(a[i]:4);
  end;

  writeln;
  max:= a[1];
  for i:=1 to k do
    if a[i]>max then max:=a[i];
  writeln('Максимальный элемент: ',max);
  writeln ('Сумма первого и максимального элементов: ',max+a[1])
end.

4,5(79 оценок)
Открыть все ответы
Ответ:
Matka2002
Matka2002
05.01.2022
Выполняя алгоритм, получаем следующий результат (15 итераций)

1. 0..65534 -> 32767
2. 0..32766 -> 16383
3. 0..16382 -> 8191
4. 0..8190  -> 4095
5. 0..4094  -> 2047
6. 2048..4094 -> 3071
7. 2048..3070 -> 2559
8. 2560..3070 -> 2815
9. 2816..3070 -> 2943
10. 2944..3070 -> 3007
11. 2944..3006 -> 2975
12. 2976..3006 -> 2991
13. 2992..3006 -> 2999
14. 3000..3006 -> 3003
15. 3000..3002 -> 3001

Если лень перебирать вручную, можно воспользоваться программой

var k,l,r,x,f:integer;
begin
f := 3001;
l := 0;
r := 65534;
x := (l + r) div 2;
k := 1;
while (x <> f) and (l < r) do
  begin
  writeln(k,' ',l,' ',r,' ',x);
  k := k + 1;
  if f < x then r := x - 1
    else l := x + 1;
  x := (l + r) div 2
  end;
writeln(k,' ',l,' ',r,' ',x);
end.
4,8(9 оценок)
Ответ:
alsumadiarova
alsumadiarova
05.01.2022
Для начала стоит сказать, что Вы используете неправильный модуль. Вам нужен vk_api.bot_longpoll.

Отследить выход человека из беседы можно, проверяя сообщение на наличие ключа action с типом chat_kick_user.

Пример (Python 3.8+):

from vk_api import VkApi
from vk_api.bot_longpoll import VkBotLongPoll, VkBotEventType

ACCESS_TOKEN = '' # Подставьте свой!
GROUP_ID = # Подставьте свой!

vk_session = VkApi(token=ACCESS_TOKEN)
vk = vk_session.get_api()
longpoll = VkBotLongPoll(vk_session, GROUP_ID)

def main():
for event in longpoll.listen():
if event.type == VkBotEventType.MESSAGE_NEW and (action := event.obj['message'].get('action')):
if action['type'] == 'chat_kick_user':
vk.messages.removeChatUser(
chat_id=event.chat_id,
user_id=action['member_id'],
)

if __name__ == '__main__':
main()
Не забудьте, что боту необходимо выдать права администратора беседы
4,6(89 оценок)
Это интересно:
Новые ответы от MOGZ: Информатика
logo
Вход Регистрация
Что ты хочешь узнать?
Спроси Mozg
Открыть лучший ответ