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

Язык программирования -python
задача 1.

Напишите программу, которая должна найти среди трех чисел, минимальное четное.

Задача 2.

Напишите программу, которая должна определить, пройдет ли кирпич в отверстие. Размеры отверстия (длина и высота) вводит пользователь. Тоже самое касается габаритов кирпича, пользователь вводит в программу значения длины, ширины и высоты кирпича.

Задача 3.

Пользователь вводит число, необходимо вычислить количество разрядов в числе. Например, в числе «1234» - 4 разряда, в числе «0» – 1 разряд.

Задача 4.

Пользователь вводит число, если число четное, нужно вычислить для него факториал.

Задача 5.

В списке (размером N, элементы вводим с клавиатуры) найти разницу между максимальным четным и минимальным нечетным.

👇
Ответ:
margaritrw
margaritrw
27.11.2020

1)a=int(input("Введите первое число"))

b=int(input("Введите второе число"))

c=int(input("Введите третье число"))

if((b>a)and(c>a)and(a/2 in range(1,100000000,1))):

print(f"Среди трёх введеных чисел минимальным чётным является{a}")

elif((a>b)and(c>b)and(b/2 in range(1,100000000,1))):

print(f"Среди трёх введеных чисел минимальным чётным является{b}")

elif((b>c)and(a>c)and(c/2 in range(1,100000000,1))):

print(f"Среди трёх введеных чисел минимальным чётным является{c}")

2)a=int(input("Введите длину отверстия"))

b=int(input("Введите ширину отверстия"))

c=int(input("Введите высоту отверстия"))

d=int(input("Введите длину кирпича"))

e=int(input("Введите ширину кирпича"))

f=int(input("Введите высоту кирпича"))

if((a>=d)and(b>=e)and(c>=f)):

print("Кирпич влезет")

else:

print("Кирпич не влезет")

3)a=str(input())

i=0

e=0

b=["1","2","3","4","5","6","7","8","9","0"]

while(1==1):

if(a[i:i+1] in b):

e=e+1

else:

break

i=i+1

print(e)

4,4(53 оценок)
Открыть все ответы
Ответ:
Natte1
Natte1
27.11.2020

Самая оптимальная стратегия угадывания - дихотомия, то есть деление отрезка пополам и задавание вопроса больше? (или меньше?)

Например, загадано 50

Последовательность

32   64/2            больше

48   (32+64)/2   больше

56   (48+64)/2   меньше

52   (48+56)/2   меньше

50   (48+52)/2   попал

 

Теперь о задаче. Вопрос очень некорректный, если бы он звучал, как сколько попыток нужно сделать, чтобы угадать? , то решение простое

64 = 2^6, поэтому нужно 6 попыток 6 = 110b, значит 3 бит достаточно, чтобы в них разместить это количество попыток.

НО в задаче вопрос-то другой! Потому что в процессе отгадывания на каждом шаге нужно знать 1. Концы отрезка, 2. ответ

Концы это 6 бит и 6 бит +ответ 1 бит, итого 13 бит на шаг *6 = 78 бит. Можно ещё сократить немного, так как в последующем вопросе используется информация из предыдущего(один из концов интервала).

Уточни, что имеется в виду под фразой "какое количество информации", иначе задача неопределена и допускает многочисленные толкования.

 

 

4,6(61 оценок)
Ответ:
A1mSh1k
A1mSh1k
27.11.2020
//PascalABC.NET 3.1 сборка 1200
begin
  var n := ReadInteger('n=');
  var a := MatrixRandom(n, n, 0, 10);
  println(a);
 
  var d := new System.Collections.Generic.Dictionary<integer, integer>();
  for var i := a.GetLowerBound(0) to a.GetUpperBound(0) do
    for var j := a.GetLowerBound(1) to a.GetUpperBound(1) do
    begin
      if d.ContainsKey(a[i, j]) then
        d[a[i, j]] += 1
      else
        d.Add(a[i, j], 1);
    end;
    
  var p := d.OrderByDescending(x -> x.Value).First();
  println('Чаще всего встречается ' + p.Key + ', ' + p.Value + ' раз');
end.
4,4(72 оценок)
Это интересно:
Новые ответы от MOGZ: Информатика
logo
Вход Регистрация
Что ты хочешь узнать?
Спроси Mozg
Открыть лучший ответ