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

Python Здравствуйте, не могу понять как точно и коротко написать этот код желательно с объяснением ​


Python Здравствуйте, не могу понять как точно и коротко написать этот код желательно с объяснением ​

👇
Ответ:

Если использовать только if/elif/else, то получится что-то такое.

Запрашиваем у пользователя название фрукта, затем присваиваем нашим переменным значения в зависимости от фрукта, если же введен фрукт, которого нет в условии задачи, то выведем сообщение об этом.

fruit = input("Введите название фрукта: ").lower()

if fruit == "вишня":

   small = True

   green = False

   print(f"Фрукт маленький - {small} Растение зеленое - {green}")

elif fruit == "горошек":

   small = True

   green = True

   print(f"Фрукт маленький - {small} Растение зеленое - {green}")

elif fruit == "арбуз":

   small = False

   green = True

   print(f"Фрукт маленький - {small} Растение зеленое - {green}")

elif fruit == "тыква":

   small = False

   green = False

   print(f"Фрукт маленький - {small} Растение зеленое - {green}")

else:

   print("Мы не знаем такого фрукта :) ")

4,7(64 оценок)
Ответ:
lianochkaya14
lianochkaya14
25.05.2020

small = input('Оно маленькое? ') == 'yes'

green = input('Оно зеленое? ') == 'yes'

# Вишня

if small and not green:

   print('Вишня мелкая и красная, это может быть вишня!')

else:

   print('Вишня мелкая и красная, это не вишня!')

# Горох

if small and green:

   print('Горох мелкий и зеленый, это может быть горох!')

else:

   print('Горох мелкий и зеленый, это не горох!')

# Арбуз

if not small and green:

   print('Арбуз крупный и зеленый, это может быть арбуз!')

else:

   print('Арбуз крупный и зеленый, это не арбуз!')

# Тыква

if not small and not green:

   print('Тыква крупная и оранжевая, это может быть тыква!')

else:

   print('Тыква крупная и оранжевая, это не тыква!')

4,7(80 оценок)
Открыть все ответы
Ответ:
natalijamatijch
natalijamatijch
25.05.2020
Каждая из компонент связности должна быть кликой (иначе говоря, каждые две вершины в одной компоненте связности должны быть связаны ребром). Если в i-ой компоненте связности n_i вершин, то общее число рёбер будет суммой по всем компонентам связности:

\displaystyle \sum_{i=1}^K\frac{n_i(n_i-1)}2=\frac12\sum_{i=1}^K n_i^2-\frac12\sum_{i=1}^Kn_i=\frac12\sum_{i=1}^K n_i^2-\frac N2

Требуется найти максимум этого выражения (т.е. на самом деле - максимум суммы квадратов) при условии, что сумма всех ni равна N и ni - натуральные числа.

Если K = 1, то всё очевидно - ответ N(N - 1)/2. Пусть K > 1.

Предположим, n1 <= n2 <= ... <= nK - набор чисел, для которых достигается максимум, и n1 > 1. Уменьшим число вершин в первой компоненте связности до 1, а оставшиеся вершины "перекинем" в K-ую компоненту связности. Вычислим, как изменится сумма квадратов:
\Delta(\sum n_i^2)=(1^2+(n_K+n_1-1)^2)-(n_1^2+n_K^2)=2(n_1-1)(n_K-1)
Поскольку по предположению n1 > 1 (тогда и nK > 1), то сумма квадратов увеличится, что противоречит предположению о том, что на выбранном изначально наборе достигается максимум. Значит, максимум достигается, если наименьшая по размеру компонента связности - изолированная вершина. Выкинем эту компоненту связности, останутся K - 1 компонента связности и N - 1 вершина. Будем продолжать так делать, пока не останется одна вершина, тогда получится, что во всех компонентах связности кроме последней должно быть по одной вершине.

Итак, должно выполняться
n_1=n_2=\cdots=n_{K-1}=1;\qquad n_K=N-K+1

Подставив в исходную формулу, получаем
\displaystyle\frac{(N-K)(N-K+1)}{2}

Это и есть ответ.
4,7(55 оценок)
Ответ:
Ytbjfdg
Ytbjfdg
25.05.2020
Var
a:array[1..100,1..100] of integer;
c:array[1..20,1..20] of real;
b:array[1..20,1..20] of real;
i,j,n,k:integer;
t:real;
r:integer;
begin
randomize;
t:=0;
Writeln('Введите порядок матрицы: ');
readln(n);
for i:=1 to n do
for j:=1 to n do
begin
a[i, j] := random(10); 
end;
for i:=1 to n do
for j:=1 to n do
begin
b[i,j]:=1/i+j-1;
end;
for i:=1 to n do
for j:=1 to n do
begin
for k:=1 to n do
begin
t :=t+a[i,k]*b[k, j];
end;
c[i,j]:=t;
t:=0;
end;
for i:=1 to n do
begin
for j:=1 to n do
begin
write(' ',c[i,j]:2:2);
end;
Writeln;
end;

end.
4,5(82 оценок)
Это интересно:
Новые ответы от MOGZ: Информатика
logo
Вход Регистрация
Что ты хочешь узнать?
Спроси Mozg
Открыть лучший ответ