Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.56/68: Рейтинг темы: голосов - 68, средняя оценка - 4.56
4 / 4 / 2
Регистрация: 20.06.2010
Сообщений: 147

Деление по модулю отрицательных чисел

10.10.2012, 23:01. Показов 13980. Ответов 5
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Какие в математике правила для деления по модулю отрицательных чисел?
Например -15(mod 26).
Почему в этом случае С++(mvc++) дает результат 7?
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
10.10.2012, 23:01
Ответы с готовыми решениями:

Найти произведения 4-х отрицательных и 4-х положительных чисел, и большее из них по модулю
Написать программу, которая вычисляет произведение отри¬цательных и положительных заданных четырех чисел, а затем сообщает, какое из...

Деление отрицательных чисел
Добрый вечер. Пытаюсь разобраться в простой задачке. необходимо решить пример : (3*(7+12)-2*12*5)/(6-9). Реализовываю через masm32....

Деление отрицательных чисел
При работе с отрицательными числами возникает ошибка деления на ноль, из за этого не получается сделать правильную работу с отрицательными...

5
 Аватар для nullpointer
48 / 48 / 14
Регистрация: 30.03.2009
Сообщений: 523
10.10.2012, 23:42
Не знаю что у вас там неправильно считает, но у меня ответ верный выдает равный 11.
Попробуйте написать так -15%26 это тоже самое.
0
~ Эврика! ~
 Аватар для OhMyGodSoLong
1258 / 1007 / 74
Регистрация: 24.07.2012
Сообщений: 2,002
11.10.2012, 00:06
Лучший ответ Сообщение было отмечено как решение

Решение

Деление с остатком числа a на b — это представление a в виде bq + r, где r ∈ [0; b). Такой способ единственнен. Для вашего случая: –15 = 26 × –1 + 11.

Что касается С++, то по стандарту % должен удовлетворять уравнению (a / b) * b + a % b == a. То есть должен вообще возвращать –15, так как -15 / 26 == 0.
4
4 / 4 / 2
Регистрация: 20.06.2010
Сообщений: 147
11.10.2012, 00:11  [ТС]
(a / b) * b + a % b == a.
(a / b) * b зачем умножение на b в формуле

Добавлено через 2 минуты
как я понял изза того что там целочисленное деление
0
~ Эврика! ~
 Аватар для OhMyGodSoLong
1258 / 1007 / 74
Регистрация: 24.07.2012
Сообщений: 2,002
11.10.2012, 00:15
Потому что ⌊a / b⌋ = (a − a mod b) / b, где ⌊a⌋ = округление вниз a.

Но в C++ ⌊a⌋ трактуется (обычно, в стандарте так и написано) как [a] — целая часть, округление к нулю. Немного нетождественных преобразований — и получаем, что должно выходить –15. В принципе, это не нарушает первое уравнение, если забить на ограничение значения остатка: –15 = 26 × 0 + (–15), но выглядит странно.
0
Эксперт С++
 Аватар для Thinker
4267 / 2241 / 203
Регистрация: 26.08.2011
Сообщений: 3,802
Записей в блоге: 5
11.10.2012, 08:23
Добавлю. Сама теорема звучит так:
для любых целых a и b, https://www.cyberforum.ru/cgi-bin/latex.cgi?b\neq 0, существует, и притом единственное, разложение вида
a = bq+r, где q,r - целые и https://www.cyberforum.ru/cgi-bin/latex.cgi?0\leq r < |b|.
Из этой теоремы получается важное следствие:
для любых целых a и b, https://www.cyberforum.ru/cgi-bin/latex.cgi?b>1, существует, и притом единственное, разложение вида
https://www.cyberforum.ru/cgi-bin/latex.cgi?a = a_tb^t+...+a_1b+a_0, где https://www.cyberforum.ru/cgi-bin/latex.cgi?0\leq a_0,...,a_t < b. Коэффициенты данного разложения это цифры числа a в b-ичной системе счисления:
https://www.cyberforum.ru/cgi-bin/latex.cgi?a = (a_t...a_1a_0)_b
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
11.10.2012, 08:23
Помогаю со студенческими работами здесь

Деление отрицательных чисел
Господа, нуждаюсь в вашей помощи. Имеется небольшой пример в котором одно из действий это деление -12 на 2. Вот данная часть кода ...

Целочисленное деление отрицательных чисел
Доброго времени суток. print(+6//4) # Вывод: 1 print(-6//4) # Вывод: -2 Почему так происходит? Спасибо.

Деление двух отрицательных чисел
Друзья, есть программка выполняющая различные арифметические действия. Первые три действия все правильно идет, а вот вторые 2 непонятно....

Посчитать отрицательных чисел, меньших по модулю заданного значения
Доброго времени суток, я написал небольшую программу, во время проверки увидел, что число -2147483648 не отрабатывает верно, не могли бы вы...

Вычислить произведения положительных и отрицательных чисел, сравнить их по модулю


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

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Новые блоги и статьи
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
SDL3 для Web (WebAssembly): Вывод текста со шрифтом TTF с помощью SDL3_ttf
8Observer8 01.02.2026
Содержание блога В этой пошаговой инструкции создадим с нуля веб-приложение, которое выводит текст в окне браузера. Запустим на Android на локальном сервере. Загрузим Release на бесплатный. . .
SDL3 для Web (WebAssembly): Сборка C/C++ проекта из консоли
8Observer8 30.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
SDL3 для Web (WebAssembly): Установка Emscripten SDK (emsdk) и CMake для сборки C и C++ приложений в Wasm
8Observer8 30.01.2026
Содержание блога Для того чтобы скачать Emscripten SDK (emsdk) необходимо сначало скачать и уставить Git: Install for Windows. Следуйте стандартной процедуре установки Git через установщик. . . .
SDL3 для Android: Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования. Часть библиотеки BedvitCOM Использованы. . .
SDL3 для Android: Загрузка PNG с альфа-каналом с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
SDL3 для Android: Загрузка PNG с альфа-каналом с помощью SDL3_image
8Observer8 27.01.2026
Содержание блога SDL3_image - это библиотека для загрузки и работы с изображениями. Эта пошаговая инструкция покажет, как загрузить и вывести на экран смартфона картинку с альфа-каналом, то есть с. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru