func.py 17 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756
  1. # def sum_num(s):
  2. # summa = 0
  3. # for i in s:
  4. # if i.isdigit():
  5. # summa += int(i)
  6. # print(summa)
  7. # sum_num('asd12312asdf')
  8. #~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
  9. # def get_body_mass_index(weight, height):
  10. # index = weight/((height*0.01)**2)
  11. # if index < 18.5:
  12. # print('Недостаточная масса тела')
  13. # elif 18.5 <= index <= 25.0:
  14. # print('Норма')
  15. # else:
  16. # print('Избыточная масса тела')
  17. # get_body_mass_index(70, 170)
  18. #~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
  19. # def check_password(psw):
  20. # f1 = False
  21. # digit_cnt = 0
  22. # cap = False
  23. # sim = False
  24. # for i in psw:
  25. # if i.isdigit():
  26. # digit_cnt += 1
  27. # if i.istitle():
  28. # cap = True
  29. # if i in "!@#$%":
  30. # sim = True
  31. # if (digit_cnt >= 3) and cap == True and sim == True and len(psw) >= 10:
  32. # print('Perfect password')
  33. # else:
  34. # print('Easy peasy')
  35. #~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
  36. # def count_letters(s):
  37. # cap_cnt = 0
  38. # uncap_cnt = 0
  39. # for i in s:
  40. # if i.isalpha():
  41. # if i.istitle():
  42. # cap_cnt += 1
  43. # else:
  44. # uncap_cnt += 1
  45. # print('Количество заглавных символов:', cap_cnt)
  46. # print('Количество строчных символов:', uncap_cnt)
  47. #~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
  48. # def foo():
  49. # print('function foo')
  50. # a = foo()
  51. # print(a)
  52. #~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
  53. # def find_duplicate(lst):
  54. # my_list = []
  55. # new_l = []
  56. # for i in lst:
  57. # if i not in my_list:
  58. # my_list.append(i)
  59. # for i in my_list:
  60. # if lst.count(i) > 1:
  61. # new_l.append(i)
  62. # return new_l
  63. # print(find_duplicate([1, 1, 1, 1, 1, 2, 2, 2, 2]))
  64. #~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
  65. def first_unique_char(s):
  66. s.lower()
  67. for i in range(len(s)):
  68. if s.count(s[i]) == 1:
  69. return i
  70. else:
  71. return -1
  72. # print(first_unique_char('aasssddddddddq'))
  73. #~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
  74. def format_name_list(names: list):
  75. length = len(names)
  76. s = ""
  77. if length == 0:
  78. return ""
  79. elif length == 1:
  80. return names[0].get("name")
  81. elif length == 2:
  82. return names[0].get("name") + ' и ' + names[1].get("name")
  83. else:
  84. for i in range(len(names) - 1):
  85. s += names[i].get("name") + ', '
  86. return s[:-2] + " и " + names[-1].get("name")
  87. # print(format_name_list([{'name': 'Bart'}, {'name': 'Lisa'}, {'name': 'Maggie'},
  88. # {'name': 'Homer'}, {'name': 'Marge'}]))
  89. #~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
  90. def get_domain_name(url : str):
  91. my_list = []
  92. if url.find("//") != -1:
  93. my_list = url.split("//")
  94. if my_list[1].find("www") != -1:
  95. my_list = my_list[1].split(".")
  96. return my_list[1]
  97. else:
  98. my_list = my_list[1].split(".")
  99. return my_list[0]
  100. else:
  101. my_list = url.split(".")
  102. return my_list[1]
  103. # assert get_domain_name("http://google.com") == "google"
  104. # assert get_domain_name("http://google.co.jp") == "google"
  105. # assert get_domain_name("www.xakep.ru") == "xakep"
  106. # assert get_domain_name("https://youtube.com") == "youtube"
  107. # assert get_domain_name("http://github.com/carbonfive/raygun") =='github'
  108. # assert get_domain_name("http://www.zombie-bites.com") == 'zombie-bites'
  109. # assert get_domain_name("https://www.siemens.com") == 'siemens'
  110. # assert get_domain_name("https://www.whatsapp.com") == 'whatsapp'
  111. # assert get_domain_name("https://www.mywww.com") == 'mywww'
  112. # print('Проверки пройдены')
  113. #~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
  114. def factorial(n):
  115. fact = 1
  116. for num in range(2, n + 1):
  117. fact *= num
  118. return fact
  119. def trailing_zeros(n):
  120. s = str(factorial(n))[::-1]
  121. l = []
  122. for i in range(len(s)):
  123. if s[i] != '0':
  124. break
  125. else:
  126. l.append(s[i])
  127. return len(l)
  128. # assert trailing_zeros(0) == 0
  129. # assert trailing_zeros(6) == 1
  130. # assert trailing_zeros(30) == 7
  131. # assert trailing_zeros(12) == 2
  132. #~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
  133. def count_AGTC(dna):
  134. return dna.count('A'), dna.count('G'), dna.count('T'), dna.count('C')
  135. # assert count_AGTC('AGGTC') == (1, 2, 1, 1)
  136. # assert count_AGTC('AAAATTT') == (4, 0, 3, 0)
  137. # assert count_AGTC('AGTTTTT') == (1, 1, 5, 0)
  138. # assert count_AGTC('CCT') == (0, 0, 1, 2)
  139. # print('Проверки пройдены')
  140. #~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
  141. def foo():
  142. "Эта функция делает что-то"
  143. pass
  144. # print(foo.__doc__)
  145. class Model:
  146. """
  147. This is class model
  148. """
  149. pass
  150. # help(Model)
  151. # print(Model.__doc__)
  152. def get_even(lst, number):
  153. """_summary_
  154. Args:
  155. lst (_type_): _description_
  156. number (_type_): _description_
  157. """
  158. #~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
  159. # first : int = 100
  160. # def add_numbers(a: int, b: int | float | str) -> int:
  161. # return a + b
  162. # print(add_numbers.__annotations__)
  163. #~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
  164. from typing import List, Dict, Tuple, Optional, Any, Union
  165. def list_upper(lst: List[str]):
  166. for elem in lst:
  167. print(elem.upper())
  168. # e: Any = 12
  169. # e = "sdfsdf"
  170. #~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
  171. def first_repeated_word(s: str):
  172. """Находит первый дубль в строке
  173. Args:
  174. s (str): строка
  175. Returns:
  176. str: первое повторяющееся слово
  177. """
  178. l = s.split()
  179. d_index = dict()
  180. for i in range(len(l)):
  181. if (l.count(l[i]) > 1) and l[i] not in d_index.values():
  182. d_index.update({l.index(l[i], i+1, len(l)) : l[i]})
  183. if len(d_index) == 0:
  184. return None
  185. m = len(l)
  186. if m == 0:
  187. return None
  188. for key,value in d_index.items():
  189. if key < m:
  190. m = key
  191. return d_index.get(m)
  192. # assert first_repeated_word("ab ca bc ab") == "ab"
  193. # assert first_repeated_word("ab ca bc Ab cA aB bc") == "bc"
  194. # assert first_repeated_word("ab ca bc ca ab bc") == "ca"
  195. # assert first_repeated_word("hello hi hello") == "hello"
  196. # print(first_repeated_word.__doc__)
  197. #~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
  198. def shift_letter(sim: str, shift: int):
  199. """Функция сдвигает символ letter на shift позиций """
  200. code = ord(sim) - 97
  201. if shift >= 0:
  202. shift = shift - 26*(shift//26)
  203. if (code + 97 + shift) >= 122:
  204. return chr(code + 97 + shift - 26)
  205. else:
  206. return chr(code + 97 + shift)
  207. else:
  208. shift *= -1
  209. shift = shift - 26*(shift//26)
  210. if (code + 97 - shift) < 97:
  211. return chr(code + 97 + 26 - shift)
  212. else:
  213. return chr(code + 97 - shift)
  214. # assert shift_letter('b', 2) == 'd'
  215. # assert shift_letter('d', 1) == 'e'
  216. # assert shift_letter('z', 1) == 'a'
  217. # assert shift_letter('d', -2) == 'b'
  218. # assert shift_letter('d', 26) == 'd'
  219. # assert shift_letter('b', -3) == 'y'
  220. def caesar_cipher(message: str, shift: int):
  221. """Шифр цезаря"""
  222. my_str = ""
  223. for i in message:
  224. if i.isalpha():
  225. my_str += shift_letter(i, shift)
  226. else :
  227. my_str += i
  228. return my_str
  229. # assert caesar_cipher('leave out all the rest', -1) == 'kdzud nts zkk sgd qdrs'
  230. # assert caesar_cipher('one more light', 3) == 'rqh pruh oljkw'
  231. #~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
  232. MIN_DRIVING_AGE = 18
  233. def allowed_driving(name: str, age: int) -> None:
  234. global MIN_DRIVING_AGE
  235. if (age >= MIN_DRIVING_AGE):
  236. print(name, "может водить")
  237. else:
  238. print(name, "еще рано садиться за руль")
  239. # allowed_driving('tim', 17)
  240. #~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
  241. def get_word_indices(strings: list) -> dict:
  242. l = []
  243. d = {}
  244. for i in strings:
  245. l.append(i.lower().split())
  246. for i in range(len(l)):
  247. for j in l[i]:
  248. if j not in d.keys():
  249. d.setdefault(j, [i])
  250. else:
  251. short_list = d.get(j)
  252. short_list.append(i)
  253. d.update({j: short_list})
  254. return d
  255. # assert get_word_indices(['Look at my horse', 'my horse', 'is amazing']) == {'look': [0], 'at': [0], 'my': [0, 1], 'horse': [0, 1], 'is': [2], 'amazing': [2]}
  256. def foo(a: int, b: int) -> int:
  257. return a + b
  258. # foo(b=2, 3)
  259. #~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
  260. def replace(text: str, old: str, new: str = ''):
  261. s = ''
  262. for i in text:
  263. if i == old:
  264. s += new
  265. else:
  266. s += i
  267. return s
  268. # assert replace('Нет', 'т') == 'Не'
  269. # assert replace('Bella Ciao', 'a') == 'Bell Cio'
  270. # assert replace('nobody; i myself farewell analysis', 'l', 'z') == 'nobody; i mysezf farewezz anazysis'
  271. # assert replace('commend me to my kind lord meaning', 'M', 'w') == 'commend me to my kind lord meaning'
  272. #~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
  273. def make_header(header: str, h_size : int = 1):
  274. return "<h" + str(h_size) + ">" + header + "</h" + str(h_size) + ">"
  275. # print(make_header("hello", 6))
  276. #~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
  277. def append_to_list(value, my_list = None):
  278. if my_list is None:
  279. my_list = []
  280. my_list.append(value)
  281. print(my_list, id(my_list))
  282. # append_to_list(77)
  283. #~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
  284. def create_matrix(size : int = 3, up_fill : int = 0, down_fill : int = 0):
  285. l = [[i if i == j else 0 for j in range(1, size + 1) ] for i in range(1, size + 1)]
  286. for i in range(0, size):
  287. for j in range(0, size):
  288. if j > i:
  289. l[i][j] = up_fill
  290. elif j < i:
  291. l[i][j] = down_fill
  292. return l
  293. # print(create_matrix(size=4, up_fill=7, down_fill=9))
  294. #~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
  295. # Передача значений
  296. # *a, b, c = [True, 7, 'hello', 4, False, 5]
  297. # print(a, b, c)
  298. # s = [4, 10]
  299. # print(list(range(*s)))
  300. def f(a, b, c, d):
  301. print(a, b, c, d)
  302. # Распаковка картежа
  303. # a = ('hello', True, 78, [3, 4, 5])
  304. # f(*a)
  305. # Передача неопределенного количество неименованных аргументов
  306. # Получится картеж
  307. # def f(*args):
  308. # s = 0
  309. # for i in args:
  310. # s += i
  311. # return s
  312. # print(f(1, 2, 3, 4, 5))
  313. # Передача неопределенного количества именованных аргументов
  314. # Получится словарь
  315. # def f(**kwargs):
  316. # for k, v in kwargs.items():
  317. # print(k, v)
  318. # f(a = 1, b = 5, c = 6, name = 123)
  319. # Комбинация метовдов передачи
  320. #
  321. # def f(*args, **kwargs):
  322. # print(args, kwargs)
  323. # f(5, 4, 5, 6, 1, a = 1, b = 5, c = 6, name = 123)
  324. # def outPrint(*args, sep = '#', end = '@'):
  325. # print(args, sep, end)
  326. # outPrint(1, 2, 3, 4, 5, end=111)
  327. # Распаковка
  328. # a = [1, 2, 3, 4]
  329. # print(*a)
  330. # a, b, *c = range(5)
  331. # a, *b, c = 'No money', 'no honey'
  332. # print(a, b, c)
  333. #~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
  334. def only_one_positive(*args):
  335. cnt = 0
  336. for i in args:
  337. if i >= 0:
  338. cnt += 1
  339. return cnt == 1
  340. # print(only_one_positive(0,0,0,0,5430,0,0,0,0,0))
  341. #~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
  342. def print_goods(*args):
  343. cnt = 1
  344. for i in args:
  345. if type(i) == str and len(i) > 0:
  346. print(cnt, ". ", i, sep='')
  347. cnt += 1
  348. if cnt == 1:
  349. print("Нет товаров")
  350. # print_goods(1, True, 'Грушечка', '', 'Pineapple')
  351. # def info_kwargs(**kwargs):
  352. # print('\n'.join([f'{k} = {v}' for k, v in sorted(kwargs.items())] -> ))
  353. #~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
  354. def info_kwargs(**kwargs):
  355. for k, v in sorted(kwargs.items()):
  356. print(f'{k} = {v}')
  357. # info_kwargs(first_name="John", last_name="Doe", age=33)
  358. #~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
  359. def f(*args, **kwargs):
  360. print(args, kwargs)
  361. # f(5, 4, 5, 6, 1, a = 1, b = 5, c = 6, name = 123)
  362. def create_actor(**kwargs):
  363. d = {'name': 'Райан',
  364. 'surname': 'Рейнольдс',
  365. 'age': 46}
  366. d.update(kwargs)
  367. return d
  368. # print(create_actor(name='Jack', age=20))
  369. #~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
  370. # Рекурсия
  371. def fact(x):
  372. if x == 1:
  373. return 1
  374. return fact(x-1)*x
  375. # print(fact(4))
  376. # Fibonacci
  377. # def fib(n):
  378. # if n == 1:
  379. # return 0
  380. # if n == 2:
  381. # return 1
  382. # return fib(n - 1) + fib(n - 2)
  383. # print(fib(10))
  384. # Палиндром
  385. def palindrom(s):
  386. if len(s) <= 1:
  387. return True
  388. if s[0] != s[-1]:
  389. return False
  390. return palindrom(s[1:-1])
  391. # print(palindrom("шалаш"))
  392. #~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
  393. def print_from(n: int):
  394. if n == 0:
  395. return
  396. print(n)
  397. return print_from(n - 1)
  398. # print_from(5)
  399. #~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
  400. def print_to(n: int):
  401. if n < 1:
  402. return
  403. print_to(n - 1)
  404. print(n)
  405. # print_to(3)
  406. def req(l : list) -> None:
  407. if len(l) == 0:
  408. return
  409. req(l[1:])
  410. print(l[0], end=' ')
  411. # req(list(map(int, input().split())))
  412. #~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
  413. def double_fact(n : int) -> int:
  414. if n == 1:
  415. return 1
  416. elif n == 2:
  417. return 2
  418. return n*double_fact(n - 2)
  419. # print(double_fact(7))
  420. #~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
  421. def fib(n : int) -> int:
  422. if n == 0:
  423. return 0
  424. elif n == 1:
  425. return 1
  426. return fib(n - 1) + fib(n - 2)
  427. # print(fib(7))
  428. def tribonacci(n : int) -> int:
  429. if n == 0 or n == 1:
  430. return 0
  431. elif n == 2:
  432. return 1
  433. return tribonacci(n - 1) + tribonacci(n - 2) + tribonacci(n - 3)
  434. # print(tribonacci(7))
  435. def get_combin(n, k):
  436. if k == 0 or k == n:
  437. return 1
  438. return(get_combin(n - 1, k) + get_combin(n - 1, k - 1))
  439. # print(get_combin(5, 2))
  440. def ackermann(m, n):
  441. if m == 0:
  442. return n + 1
  443. if m > 0 and n == 0:
  444. return ackermann(m - 1, 1)
  445. return ackermann(m - 1, ackermann(m, n - 1))
  446. # print(ackermann(3, 2))
  447. def list_sum_recursive(l : list) -> int:
  448. if len(l) == 0:
  449. return 0
  450. elif len(l) == 1 :
  451. return l[0]
  452. return l.pop() + list_sum_recursive(l)
  453. # print(list_sum_recursive([1, 2, 3]))
  454. def flatten(l : list) -> list:
  455. if not l :
  456. return []
  457. if isinstance(l[0], list):
  458. return flatten(l[0]) + flatten(l[1:])
  459. return l[:1] + flatten(l[1:])
  460. # print(flatten([[[[9]]], [1, 2], [[8]]]))
  461. def st(s : str) -> str:
  462. if len(s) == 1 or len(s) == 2:
  463. return s
  464. return s[0] + '(' + st(s[1:-1]) + ')' + s[-1]
  465. # print(st('123asfewrwfdsad4'))
  466. def power(x, n):
  467. if n == 0:
  468. return 1
  469. if n < 0:
  470. return 1/power(x, -n)
  471. if n%2 == 0:
  472. return power(x, n//2)*power(x, n//2)
  473. else :
  474. return power(x, n - 1)*x
  475. # print(power(2, -1))
  476. a = [1, 2,[2, 3, 4, [3, 4,[2, 3], 5]]]
  477. def rec(l, level=1):
  478. print(l, 'level = ', level)
  479. for i in l:
  480. if type(i) == list:
  481. rec(i, level + 1)
  482. # rec(a)
  483. #~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
  484. def flatten_dict(nested : dict, prefix : str = '') -> dict:
  485. result = dict()
  486. for key, value in nested.items():
  487. if type(value) == int:
  488. result.update({prefix + key: value})
  489. else:
  490. result.update(flatten_dict(value, prefix + key + '_'))
  491. return result
  492. nes = {'Germany': {'berlin': 7},
  493. 'Europe': {'italy': {'Rome': 3}},
  494. 'USA': {'washington': 1, 'New York': 4}}
  495. # print(flatten_dict({'Q': {'w': {'E': {'r': {'T': {'y': 123}}}}}}))
  496. #~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
  497. # Сортировка слиянием
  498. def merge_two_list(a, b):
  499. c = []
  500. i = j = 0
  501. while i < len(a) and j < len(b):
  502. if a[i] < b[j]:
  503. c.append(a[i])
  504. i += 1
  505. else:
  506. c.append(b[j])
  507. j += 1
  508. if i < len(a):
  509. c += a[i:]
  510. elif j < len(b):
  511. c += b[j:]
  512. return c
  513. def merge_sort(s):
  514. if len(s) == 1:
  515. return s
  516. middle = len(s)//2
  517. left = merge_sort(s[:middle])
  518. right = merge_sort(s[middle:])
  519. return merge_two_list(left, right)
  520. # print(merge_sort([7, 5, 2 ,3, 9, 8, 6]))
  521. #~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
  522. # Быстра сортировка
  523. def quick_sort(s):
  524. if len(s) <= 1:
  525. return s
  526. elem = s[0]
  527. left = list(filter(lambda x: x < elem, s))
  528. center = [i for i in s if i == elem]
  529. right = list(filter(lambda x: x > elem, s))
  530. return quick_sort(left) + center + quick_sort(right)
  531. # print(quick_sort([7, 5, 2 ,3, 9, 8, 6]))
  532. #~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
  533. # per = lambda a, b, c : a + b + c
  534. # t = lambda x: 'positive' if x > 0 else 'negative'
  535. # print(per(1, 2, 3))
  536. #~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
  537. # Сортировка по ключам
  538. # a = [321, 32, 54, 3 ,56, 45, 23423, 423, 5435, 234]
  539. # a.sort(key=lambda x: x//10%10)
  540. #~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
  541. # def linear(k, b):
  542. # return lambda x: x*k+b
  543. # graf1 = linear(2, 5)
  544. # graf2 = linear(5, 3)
  545. # print(graf1(3))
  546. # print(graf2(9))
  547. # starts_with = lambda s: True if s[0] == 'W' else False
  548. # print(starts_with("World"))
  549. # average = lambda *args: sum(*args)/len(*args)
  550. # print(average((1, 3, 6, 3)))
  551. def get_days(month):
  552. if month in (1, 3, 5, 7, 8, 10, 12):
  553. print(31)
  554. elif month == 2:
  555. print(28)
  556. else:
  557. print(30)