Форум программистов, компьютерный форум, киберфорум
C# .NET
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.64/11: Рейтинг темы: голосов - 11, средняя оценка - 4.64
0 / 0 / 0
Регистрация: 07.10.2021
Сообщений: 11

Найти период дроби

11.10.2021, 21:24. Показов 2295. Ответов 2
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Есть задача: дано число k не делящееся на 2 и 5. Вывести (в виде списка) период дроби 1/k.
В первую очередь меня даже не сама реализация волнует (хотя может на очень понятном примере было бы и лучше), а наиболее понятная интерпретация алгоритма нахождения периода. Сколько не ищу, понятного не попадалось.
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
11.10.2021, 21:24
Ответы с готовыми решениями:

Найти период дроби, как исправить ошибку
Задание: Дана дробь a / b. Определите её период. Мой вариант: using System; namespace ConsoleApplication1 { class Raschet...

Найти период и длину периода десятичной дроби.
Здравствуйте. Есть задача, которую необходимо решить с использованием Java: Дано простое число p>5. Определить длину периода...

Найти длину периода и сам период бесконечной степенной дроби по основанию Р
время поджимает, завтра сдавать. препод ни фига не объясняет!!! есть решение, осталось написать прогу на C++. Задача №1 Имеется N...

2
1168 / 886 / 517
Регистрация: 09.04.2014
Сообщений: 2,102
12.10.2021, 11:04
Цитата Сообщение от Moonissia Посмотреть сообщение
Сколько не ищу, понятного не попадалось.
1, 2, 3
0
Модератор
Эксперт .NET
 Аватар для Элд Хасп
16147 / 11268 / 2890
Регистрация: 21.04.2018
Сообщений: 33,131
Записей в блоге: 2
12.10.2021, 16:11
Цитата Сообщение от Moonissia Посмотреть сообщение
Есть задача: дано число k не делящееся на 2 и 5. Вывести (в виде списка) период дроби 1/k.
Решить можно несколькими способами.
1) Самый простой, но не всегда верный. Получить double num = 1/(double)k;. Преобразовать в строку и откинуть ведущие нули string str = string.Concat(num.ToString().SkipWhile(c => c == '0' || c = '.'));. И искать в полученной строке период как показал nedel.
Проблема такого способа: не для всех K будет получена верное значение. Для некоторых К период может быть больше мантиссы double. Не проверял, но скорее всего такое будет для int.MaxValue.

2) Программёрский точный способ. Реализуете целочисленное деление со сдвигом на разряд и получением по одному разряду. На каждом шаге получаете очередную цифру частного и остаток для последующего деления. Запоминаете их. Продолжаете до тех пор пока эта пара не повторится. Количество шагов между повтором и есть искомый период.

3) Математический, но не знаю насколько реализуем и не ошибся ли я. Используется то, что периодическая дробь приводится к обыкновенной через дробь вида (цифры периода)|999...99 - где количество девяток равно количеству цифр периода.
Получаем: https://www.cyberforum.ru/cgi-bin/latex.cgi?\frac{1}{k} = \frac{{10}^{n}-1}{k * ({10}^{n}-1)}=\frac{\frac{{10}^{n}-1}{k}}{{10}^{n}-1}

Из этого выражения, наш период равен минимальному n при котором (10n-1)/k - будет целым числом.
Ответ можно искать алгоритмически - это в раздел математики.
Или программёрски: берём n с инкриментом на каждом шаге и проверяем остаток от деления (10n-1) на k.
Скорее всего придётся использовать BigInteger.

Добавлено через 7 минут
Пример.
Для к=7 минимальное n = 6: 999'999/7 = 142'857.0
Значит период - шесть.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
12.10.2021, 16:11
Помогаю со студенческими работами здесь

Определить длину периода десятичной дроби M/N и период данной десятичной дроби M/N
Даны два натуральных числа M и N, M < N. Определить длину периода десятичной дроби M/N и период данной десятичной дроби M/N. Добавлено...

Период дроби
Добрый день! Недавно начал изучать язык с++ и наткнулся на такую задачку: вывести период дроби. С виду просто, а не выходит. Пробовал...

Период у дроби
Найти период бесконечной периодической дроби. Если десятичная дробь конечна, её период — цифра 0. Период должен начинаться с той цифры,...

Определить период дроби
Помогите пожалуйста составить программу. Нужно определить период дроби.

Определить период дроби n/m
Здравствуйте помогоите пожалуйста написать программу, определяющую период дроби n/m, где n и m – натуральные числа, спасибо:)


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
Модель ЗдрввоСохранения 7: больше работников, больше ресурсов.
anaschu 08.04.2026
работников и заданий может быть сколько угодно, но настроено всё так, что используется пока что только 20% kYBz3eJf3jQ
Дальние перспективы сервера - слоя сети с космологическим дизайном интефейса карты и логики.
Hrethgir 07.04.2026
Дальнейшее ближайшее планирование вывело к размышлениям над дальними перспективами. И вот тут может быть даже будут нужны оценки специалистов, так как в дальних перспективах всё может очень сильно. . .
Горе от ума
kumehtar 07.04.2026
Эта мне ментальная установка, что вот прямо сейчас, мол, мне для полного счастья не хватает (нужное вписать), и когда я этого достигну - тогда и полный кайф. Одна из самых сильных ловушек на пути. . . .
Использование значений реквизитов справочника в документе, с определенными условиями и правами
Maks 07.04.2026
1. Контроль срока действия договора Алгоритм из решения ниже реализован на примере нетипового документа "ЗаявкаНаРаботу", разработанного в конфигурации КА2. Задача: уведомлять пользователя, если. . .
Доступность команды формы по условию
Maks 07.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: сделать доступной кнопку (команда формы "ЗавершитьСписание") при. . .
Уведомление о неверно выбранном значении справочника
Maks 06.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "НарядПутевка", разработанного в конфигурации КА2. Задача: уведомлять пользователя, если в документе выбран неверный склад. . .
Установка Qt Creator для C и C++: ставим среду, CMake и MinGW без фреймворка Qt
8Observer8 05.04.2026
Среду разработки Qt Creator можно установить без фреймворка Qt. Есть отдельный репозиторий для этой среды: https:/ / github. com/ qt-creator/ qt-creator, где можно скачать установщик, на вкладке Releases:. . .
AkelPad-скрипты, структуры, и немного лирики..
testuser2 05.04.2026
Такая программа, как AkelPad существует уже давно, и также давно существуют скрипты под нее. Тем не менее, прога живет, периодически что-то не спеша дополняется, улучшается. Что меня в первую очередь. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru