1. запишите числа в нормальной форме представления:
a. 0,2435
b. 0,000167
c. 472,43
d. 347256
e. 245,03
f. 0,02145
2. запишите целые числа в шестнадцатиразрядную ячейку памяти в прямом
коде:
a. -124
b. 244
c. 33001
d. -512
e. 408
3. запишите числа в формате с фиксированной точкой для
выполнения арифметических действий:
a. 287,127 и 123
b. 33,427 и 0,534
4. запишите в шестнадцатиразрядную ячейку памяти в дополнительном коде:
a. 534
b. 258
c. -153
d. -1548
e. 260
f. -120
5. определите десятичное число, для которого прямой код имеет следующий
вид:
a. 11011011
b. 00011001
c. 10110110
d. 10111011
e. 1110
6. определите, какое десятичное число имеет следующий вид в
дополнительном коде:
a. 01100110
b. 1001
c. 0000
d. 11001101
7. определите, какое десятичное запишется в итоге в восьмиразрядную ячейку
памяти (прямой код) //для каждого из значений:
a. 550
b. -246
c. 409
d. 23
e. -1005
f. -410
8. запишите числа в формате с плавающей точкой:
a. -90,15
b. 0,03
def shortest_chains(n):
def next_chains(chain):
new_elems = set()
for i in range(len(chain)):
for j in range(i, len(chain)):
new_elem = chain[i] + chain[j]
if new_elem > chain[-1] and new_elem not in new_elems:
new_elems.add(new_elem)
yield chain + [new_elem]
current_stage = None
next_stage = [[1]]
answer = []
while len(answer) == 0:
current_stage = next_stage
next_stage = []
for chain in current_stage:
next_stage.extend(next_chains(chain))
answer = [chain[1:] for chain in next_stage if chain[-1] == n]
return answer
def print_solution(n):
answer = shortest_chains(n)
print("Для {} есть {} решений(-я, -е):".format(n, len(answer)))
for i in range(len(answer)):
print("{}. {}".format(i + 1, " ".join(map(str, answer[i]
print()
Запустив, можно получить все 5 возможных решений для числа 7, по 4 решения для 15 и 23 и 87 решений для 63.