Last active
February 15, 2024 21:27
-
-
Save bannovGB/93a68730112487e17d9aa66a1ea4989d to your computer and use it in GitHub Desktop.
Python_lesson03
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
'''Задача 16: Требуется вычислить, сколько раз встречается некоторое число X в массиве A[1..N]. | |
Пользователь в первой строке вводит натуральное число N – количество элементов в массиве. | |
В последующих строках записаны N целых чисел Ai. Последняя строка содержит число X | |
5 | |
1 2 3 4 5 | |
3 | |
-> 1''' | |
from random import randint | |
a = [randint(1, 9) for i in range(int(input('Введите размер массива: ')))] | |
print(a) | |
print('Встречается', a.count(int(input('Введите искомое число: '))), 'раз') |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
'''Задача 18: Требуется найти в массиве A[1..N] самый близкий по величине элемент к заданному числу X. | |
Пользователь в первой строке вводит натуральное число N – количество элементов в массиве. | |
В последующих строках записаны N целых чисел Ai. Последняя строка содержит число X | |
5 | |
1 2 3 4 5 | |
6 | |
-> 5''' | |
from random import randint | |
input_set = [randint(1, 99) for i in range(int(input('Введите размер массива: ')))] | |
print(input_set) | |
num = int(input('Введите искомое число: ')) | |
input_set = set(input_set) | |
dif = 0 | |
if num > max(input_set): | |
print(max(input_set)) | |
elif num < min(input_set): | |
print(min(input_set)) | |
else: | |
while True: | |
if num - dif in input_set and num + dif in input_set and num - dif != num + dif: | |
print(num - dif, num + dif) | |
break | |
elif num - dif in input_set: | |
print(num - dif) | |
break | |
elif num + dif in input_set: | |
print(num + dif) | |
break | |
else: | |
dif += 1 |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
'''Задача 20: В настольной игре Скрабл (Scrabble) каждая буква имеет определенную | |
ценность. В случае с английским алфавитом очки распределяются так: | |
● A, E, I, O, U, L, N, S, T, R – 1 очко; | |
● D, G – 2 очка; | |
● B, C, M, P – 3 очка; | |
● F, H, V, W, Y – 4 очка; | |
● K – 5 очков; | |
● J, X – 8 очков; | |
● Q, Z – 10 очков. | |
А русские буквы оцениваются так: | |
● А, В, Е, И, Н, О, Р, С, Т – 1 очко; | |
● Д, К, Л, М, П, У – 2 очка; | |
● Б, Г, Ё, Ь, Я – 3 очка; | |
● Й, Ы – 4 очка; | |
● Ж, З, Х, Ц, Ч – 5 очков; | |
● Ш, Э, Ю – 8 очков; | |
● Ф, Щ, Ъ – 10 очков. | |
Напишите программу, которая вычисляет стоимость введенного пользователем слова. | |
Будем считать, что на вход подается только одно слово, которое содержит либо только | |
английские, либо только русские буквы. | |
Ввод: ноутбук | |
Вывод: 12''' | |
scrable = { | |
'A': 1, 'E': 1, 'I': 1, 'O': 1, 'U': 1, 'L': 1, 'N': 1, 'S': 1, 'T': 1, 'R': 1, 'А': 1, 'В': 1, 'Е': 1, | |
'И': 1, 'Н': 1, 'О': 1, 'Р': 1, 'С': 1, 'Т': 1, 'D': 2, 'G': 2, 'Д': 2, 'К': 2, 'Л': 2, 'М': 2, 'П': 2, | |
'У': 2, 'B': 3, 'C': 3, 'M': 3, 'P': 3, 'Б': 3, 'Г': 3, 'Ё': 3, 'Ь': 3, 'Я': 3, 'F': 4, 'H': 4, 'V': 4, | |
'W': 4, 'Y': 4, 'Й': 4, 'Ы': 4, 'K': 5, 'Ж': 5, 'З': 5, 'Х': 5, 'Ц': 5, 'Ч': 5, 'J': 8, 'X': 8, 'Ш': 8, | |
'Э': 8, 'Ю': 8, 'Q': 10, 'Z': 10, 'Ф': 10, 'Щ': 10, 'Ъ': 10} | |
word = str.upper(input('Введите слово: ')) | |
s = 0 | |
for i in word: | |
s += scrable[i] | |
print(s, 'очков') |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment