gif
Портал edu4cash: Что это и как работает?.
gif
Как быстро получить ответ от ИИ.
gif
Как задонатить в Roblox в России в 2024 году.
gif
Обновления на edu4cash – новые награды, улучшенная модерация и эксклюзивные возможности для VIP!.
  • Задать вопрос
  • Назад
  • Главная страница
  • Вопросы
  • Предметы
    • Русский язык
    • Литература
    • Математика
    • Алгебра
    • Геометрия
    • Вероятность и статистика
    • Информатика
    • Окружающий мир
    • География
    • Биология
    • Физика
    • Химия
    • Обществознание
    • История
    • Английский язык
    • Астрономия
    • Физкультура и спорт
    • Психология
    • ОБЖ
    • Немецкий язык
    • Французский язык
    • Право
    • Экономика
    • Другие предметы
    • Музыка
  • Темы
  • Банк
  • Магазин
  • Задания
  • Блог
  • Топ пользователей
  • Контакты
  • VIP статус
  • Пригласи друга
  • Донат
  1. edu4cash
  2. Вопросы
  3. Информатика
  4. 10 класс
  5. Блокчейн (blockchain) переводится как «цепочка блоков». Это способ хранения данных, защищённый от подделки, используемый, в частности, криптовалютой биткоин. Блокчейн действительно представляет собой последовательность блоков. Каждый блок представляет собой некоторую полезную информацию (в частности, в случае биткоина это список транзакций за определённый период времени — кто кому когда сколько денег передал), снабжённую случайным числом и некоторыми служебными данными, в том числе хэшем — числом, которое по определённой формуле зависит от остальной части блока и хэша предыдущего блока. Хэш должен быть меньше определённого числа. При этом формула, по которой вычисляется хэш, устроена так, что невозможно получить достаточно маленький хэш иначе, чем перебирая различные значения случайного числа. Поэтому если злоумышленник решит подделать блокчейн (и, допустим, вставить в его середину блок с записью о том, что все люди передают ему все свои деньги), то ему придётся подобрать новое случайное число в новое поддельном блоке и всех последующих (ведь хэш каждого следующего блока зависит от хэша предыдущего), что потребует невозможно больших вычислительных мощностей. Поэтому блокчейн в целом защищён от подобных атак. Напишите программу, которая проводит проверку правильности хэшей в модельном блокчейне с простой хэш-функцией. Блок bn с номером n включает полезную информацию mn, представленную натуральным числом, rn — случайное число от 0 до 255 и hn — хеш (целое число от 0 до 255). У каждого блока хэш вычисляется по формуле hn = 37×(mn+rn+hn-1) (по модулю 256), при вычислении хэша начального блока h0 вместо хэша предыдущего блока берётся ноль. При этом каждый блок представлен одним числом bn = hn + rn×256 + mn×2562. При этом требуется, чтобы хэш hn был меньше 100. Формат вводаНа первой строке вводится натуральное число N — количество блоков.Далее следуют N чисел bn, каждое на отдельной строке. Формат выводаСледует вывести номер первого блока, у которого неправильный хэш (не меньше 100 или не совпадает с вычисленным по указанной в условии формуле), или -1, если все хэши в блокчейне правильные. Нумерация блоков идёт с нуля, т. е. они имеют номера от 0 до N-1. напиши код на python
Задать вопрос
Похожие вопросы
  • Вводится 4-х значное число. Нужно разделить его на отдельные цифры и с их помощью записать наименьшее возможное, но тоже четырехзначное число. В задаче нельзя использовать циклы, строки и списки. Формат вводаЧетырехзначное число. Формат выводаМинимальное число, записанное теми же цифрами.   учти что число может быть с 0 самый простой способкод на python
  • После полета Юрия Гагарина в 1961 практически каждый мальчик СССР хотел стать космонавтом. Прошло уже более полувека, но профессия космонавт все так же престижна. К сожалению, не каждый желающий может пройти отбор, существуют высокие требования к уровню подготовки будущих космонавтов, а также ограничения по антропометрическим показателям. Например, рост космонавта не может быть больше 190 см и меньше 150 см. Напишите программу, которая считывает рост претендентов в отряд космонавтов до тех пор, пока не будет введен «!». А затем выводит на первой строчке количество подходящих кандидатур, а на второй строке – минимальный и максимальный рост участников, отобранных в новый отряд космонавтов. Гарантируется, что в отряд отберутся как минимум два летчика-космонавта. Формат ввода Несколько строк с ростом космонавтов и последняя строка «!». Формат вывода Две строки: количество кандидатур на первой, и минимальный и максимальный рост через пробел – на второй.
  • Сиракузская последовательность, или последовательность Коллатца, строится так: возьмём натуральное число n; если оно чётное, то заменим его числом n/2; если же оно нечётное, то заменим его числом 3n+1. Получившееся число — следующее в сиракузской последовательности после числа n. Затем заменяем получившееся число по тому же правилу, и так далее. Обычно, если проделать такую замену достаточно много раз, мы приходим к числу 1 (за которым следует снова ). Например: . Определите, сколько шагов потребуется сиракузской последовательности, стартующей с заданного числа, чтобы прийти к 1. Если вы обнаружите число, сиракузская последовательность от которого не приходит к 1, то... вы, скорее всего, ошиблись. Но если нет, то поздравляем: вы прославитесь, ведь вопрос о том, всегда ли сиракузская последовательность приходит к 1 (независимо от начального числа), давно будоражит умы математиков. Формат ввода Вводится одно натуральное число n. Формат вывода Выводится одно число — количество шагов, необходимое стартующей от n сиракузской последовательности, чтобы впервые дойти до 1.
  • Составьте алгоритм для решения следующей задачи: Дан массив A (n). Как отсортировать его в порядке убывания значений?
  • #Ввод начального числа: Начнем с ввода натурального числа n, с которого будет строиться последовательность.#Инициализация счетчика: Установим счетчик шагов в 0. Этот счетчик будет отслеживать количество операций, которые мы выполним.#Цикл выполнения: Будем повторять следующие действия, пока n не станет равным 1:#Проверка четности: Если n четное, заменяем его на n/2.#Проверка нечетности: Если n нечетное, заменяем его на 3n + 1.#Увеличение счетчика: После каждой замены увеличиваем счетчик шагов на 1.#Завершение: Как только n станет равным 1, цикл прекращается, и значение счетчика шагов будет равно количеству шагов, которые потребовались для достижения 1напиши код на python
danila.sharkoff

2024-11-10 13:37:08

Блокчейн (blockchain) переводится как «цепочка блоков». Это способ хранения данных, защищённый от подделки, используемый, в частности, криптовалютой биткоин.

Блокчейн действительно представляет собой последовательность блоков. Каждый блок представляет собой некоторую полезную информацию (в частности, в случае биткоина это список транзакций за определённый период времени — кто кому когда сколько денег передал), снабжённую случайным числом и некоторыми служебными данными, в том числе хэшем — числом, которое по определённой формуле зависит от остальной части блока и хэша предыдущего блока.

Хэш должен быть меньше определённого числа. При этом формула, по которой вычисляется хэш, устроена так, что невозможно получить достаточно маленький хэш иначе, чем перебирая различные значения случайного числа. Поэтому если злоумышленник решит подделать блокчейн (и, допустим, вставить в его середину блок с записью о том, что все люди передают ему все свои деньги), то ему придётся подобрать новое случайное число в новое поддельном блоке и всех последующих (ведь хэш каждого следующего блока зависит от хэша предыдущего), что потребует невозможно больших вычислительных мощностей.

Поэтому блокчейн в целом защищён от подобных атак.

Напишите программу, которая проводит проверку правильности хэшей в модельном блокчейне с простой хэш-функцией.

Блок bn с номером n включает полезную информацию mn, представленную натуральным числом, rn — случайное число от 0 до 255 и hn — хеш (целое число от 0 до 255). У каждого блока хэш вычисляется по формуле hn = 37×(mn+rn+hn-1) (по модулю 256), при вычислении хэша начального блока h0 вместо хэша предыдущего блока берётся ноль.

При этом каждый блок представлен одним числом bn = hn + rn×256 + mn×2562. При этом требуется, чтобы хэш hn был меньше 100.

Формат ввода
На первой строке вводится натуральное число N — количество блоков.
Далее следуют N чисел bn, каждое на отдельной строке.

Формат вывода
Следует вывести номер первого блока, у которого неправильный хэш (не меньше 100 или не совпадает с вычисленным по указанной в условии формуле), или -1, если все хэши в блокчейне правильные. Нумерация блоков идёт с нуля, т. е. они имеют номера от 0 до N-1.

напиши код на python

Информатика 10 класс Алгоритмы и структуры данных ключевые слова: блокчейн хэш проверка хэша криптовалюта биткоин Новый

Ответить

Born

2024-11-10 13:37:30

Давайте разберем, как можно решить эту задачу шаг за шагом.

Для начала, нам нужно понять, как извлечь из числа bn все необходимые компоненты: mn, rn и hn.

  1. mn можно получить, разделив число bn на 2562 и взяв целую часть от деления:
    • mn = bn // 2562
  2. rn можно получить, разделив число bn на 256, взяв остаток от деления на 256 и целую часть:
    • rn = (bn // 256) % 256
  3. hn можно получить, взяв остаток от деления числа bn на 256:
    • hn = bn % 256

Теперь, когда мы знаем, как извлечь все компоненты, давайте перейдем к проверке корректности хэшей.

  1. Заведем переменную previous_hash, которая будет хранить хэш предыдущего блока. Для начального блока она равна 0.
  2. Заведем цикл, который будет проходить по всем блокам:
    • Для каждого блока извлекаем mn, rn и hn.
    • Вычисляем ожидаемый хэш expected_hash по формуле: expected_hash = (37 * (mn + rn + previous_hash)) % 256.
    • Проверяем два условия:
      • Если hn не совпадает с expected_hash, значит, хэш блока неверен.
      • Если hn не меньше 100, значит, хэш блока неверен.
    • Если одно из условий выполняется, выводим номер блока и завершаем выполнение.
    • Если оба условия не выполняются, обновляем previous_hash значением hn и продолжаем проверку следующего блока.
  3. Если цикл завершился и не было найдено ни одного блока с неверным хэшем, выводим -1.

Теперь давайте напишем код, который реализует описанный алгоритм:

def check_blockchain(N, blocks):
    previous_hash = 0

    for i in range(N):
        bn = blocks[i]
        mn = bn // (256 ** 2)
        rn = (bn // 256) % 256
        hn = bn % 256

        expected_hash = (37 * (mn + rn + previous_hash)) % 256

        if hn != expected_hash or hn >= 100:
            return i

        previous_hash = hn

    return -1

# Пример использования:
N = int(input())
blocks = [int(input()) for _ in range(N)]
result = check_blockchain(N, blocks)
print(result)

Этот код читает количество блоков и сами блоки, затем проверяет каждый блок на корректность хэша и выводит номер первого блока с ошибкой или -1, если все блоки корректны.


danila.sharkoff ждет твоей помощи!

Ответь на вопрос и получи 10 Б 😉
Ответить

  • Политика в отношении обработки персональных данных
  • Правила использования сервиса edu4cash
  • Правила использования файлов cookie (куки)

Все права сохранены.
Все названия продуктов, компаний и марок, логотипы и товарные знаки являются собственностью соответствующих владельцев.

Copyright 2024 © edu4cash

Получите 500 балов за регистрацию!
Регистрация через ВКонтакте Регистрация через Google

...
Загрузка...
Войти через ВКонтакте Войти через Google Войти через Telegram
Жалоба

Для отправки жалобы необходимо авторизоваться под своим логином, или отправьте жалобу в свободной форме на e-mail [email protected]

  • Карма
  • Ответов
  • Вопросов
  • Баллов