Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.92/13: Рейтинг темы: голосов - 13, средняя оценка - 4.92
 Аватар для GoldenId
142 / 143 / 64
Регистрация: 11.11.2010
Сообщений: 877
Записей в блоге: 10

Codeforces, 456B - Федя и математика

06.06.2017, 07:57. Показов 2769. Ответов 1
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Страница задачи на codeforces.com

Условие
Федя учится в гимназии. Домашнее задание по математике у Феди состоит в вычислении следующего выражения:

(1n + 2n + 3n + 4n) mod 5
для заданного числа n. Федя смог выполнить это задание. А сможете ли вы? Обратите внимание, что заданное число n может быть очень большим (например, оно может не помещаться в целочисленные типы вашего языка программирования).

Входные данные
В единственной строке находится целое число n (0 ≤ n ≤ 10105). Число не содержит лидирующих нулей.

Выходные данные
Выведите значение выражения без лидирующих нулей.


Ход мысли
Сначала я думал вычислять значения степеней 2n mod 5, 3n mod 5, 4n mod 5 бинарным возведением в степень по модулю... Но число n - слишком уж большое. Его в общем случае не зачитаешь в числовую переменную.
Завёл лист в Excel и посчитал значения для первых n.
n1n%52n2n%53n3n%54n4n%5sumsum%5
0111111144
11223344100
214494161100
3183272644100
41161811256144
51322243310244100
61644729440961100
71128321872163844100
8125616561165536144
9151221968332621444100
1011024459049410485761100
11120483177147241943044100
12140961531441116777216144
1318192215943233671088644100
141163844478296942684354561100
15132768314348907210737418244100
1616553614304672114294967296144
Оказалось, что каждое слагаемое и сумма повторяется с периодом 4. А именно
Если n кратно 4, то ответ 4, иначе - 0.
Признак делимости числа на 4 в десятичной система счисления - чтобы число из последних двух его цифр делилось на 4.
То есть для реализации достаточно выкинуть все лидирующие цифры, кроме двух (или взять одну, если есть только она)
и посмотреть, делится ли число из них на 4 без остатка.


Код

К удивлению долго не получалось справиться с чтением двух символов. В частности встроенный редактор Code::Blocks упорно дописывал в файл input.txt завершающий '\n', из-за чего условие
C++
1
while( is.peek() != EOF )
срабатывало неправильно, один лишний раз. В итоге победилось следующим образом:

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
//#define CF
#include <cstddef>
#ifdef CF
#include <iostream>
#else
#include <fstream>
#endif
 
int main()
{
#ifdef CF
    std::istream& is = std::cin;
    std::ostream& os = std::cout;
#else
    std::ifstream is( "input.txt" );
    std::ofstream os( "output.txt" );
#endif // CF
 
    char ch1, ch2;
    bool one = true;
    is >> ch1;
    if( isdigit( is.peek() ) )
    {
        one = false;
        is >> ch2;
    }
    while( isdigit( is.peek() ) )
    {
        ch1 = ch2;
        is >> ch2;
    }
    if( one && ( ch1 - '0' ) % 4 == 0
        || !one && ( ( ch1 - '0' )*10 + ( ch2 - '0' ) ) % 4 == 0 )
        os << 4;
    else
        os << 0;
}
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
06.06.2017, 07:57
Ответы с готовыми решениями:

Codeforces.Double Cola
Условие задачи таково: Шелдон, Леонард, Пенни, Раджеш и Говард стоят в очереди к автомату по продаже баночек с напитком «Double Cola»,...

Задача с Codeforces, уровень A
Вроде простая задача, а я затупил. Неправильный ответ на тесте 5 Ограбление Банка Преступник попытался ограбить банк, но не смог...

Runtime error в задаче на codeforces
(p.s. что за тупая система тут: написал пост , не зная, что слово &quot;проблема&quot; в заголовке запрещена - пост стерся. Кайф:) ) Пытался...

1
 Аватар для GoldenId
142 / 143 / 64
Регистрация: 11.11.2010
Сообщений: 877
Записей в блоге: 10
06.06.2017, 08:07  [ТС]
Разбор
На удивление в разборе оба предложенных решения сложнее.


Кто шарит, объясните преобразования:

Как они сделали первое преобразование, и что за такая https://www.cyberforum.ru/cgi-bin/latex.cgi?\phi \left(n \right)?
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
06.06.2017, 08:07
Помогаю со студенческими работами здесь

Codeforces и питон
Не могу разобраться, как осуществляется ввод и вывод данных. Вводные данные:В первой строке расположены два целых числа A и B, не...

Ищу человека в команду на codeforces
Ищу человека в свою команду на codeforces для соревнований Прогаю на c++,на соревнованиях не блещу,хочу найти человека,для обоюдного...

Дискретная математика - ложная наука. Математика должна быть радикально изменена
Вопрос для всех: Где источник числовой информации для практических целей? Математиков, решающих свои математические головоломки, оставим в...

Нахождение суммы остатков (задача с Codeforces)
Здравствуйте! Сейчас я пытаюсь решить задачу. Суть такая - даются числа n и m, необходимо подсчитать сумму ряда типа n mod 1 + n mod 2...

Математика для программиста, Выш.мат, Дискретная математика, Мат.Статистика
Всем качественного контента, дело такое, сижу на 3м курсе.. В Бикини ботоме... По Прог. Обуч-я касательно математики было: Дискретная...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Access
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru