Налево,налево,вниз, ,вниз,направо,направо,вверх,вверх,налево,налево,вниз, ,вниз,налево,
итак еще4 раза
1. вычитаем 1: 1111001001111110-1=<span>1111 0010 0111 1101 (это и есть обратный код)
2. инвертируем разряды: 0000 1101 1000 0010
Так как число отрицательное, то прямой код 1</span>000 1101 1000 0010<span>
3. переводим в десятичную систему: </span>1101 1000 0010(2) = 3458(10)
Таким образом, данное число в десятичной системе счисления -3458
Для того, чтобы запись числа оканчивалась на 8, это число должно делится на основание системы счисления с остатком 8. Следовательно, число 30-8=22 должно делится на это число без остатка, причём число строго больше восьми. Получаются числа 11 и 22.
Насколько я понял, нужно перевести из двоичной системы счисления в десятичную.
Обычно это делают, умножая цифру в каждом разряде на "вес" разряда, и складывая эти произведения (естественно, все вычисления делаются по правилам десятичной системы счисления).
Я специально не стал пропускать разряды, равные нулю, чтобы была понятнее суть вычислений при переводе:
А так, их конечно можно пропустить, но главное при этом не пропускать увеличение степени, в которую возводим двойку (она увеличивается на единицу с каждым разрядом в исходном числе). Вот вариант с пропуском нулевых разрядов: