Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.73/48: Рейтинг темы: голосов - 48, средняя оценка - 4.73
5 / 0 / 0
Регистрация: 25.08.2010
Сообщений: 11

Дано натуральное число n > 1. Определить длину периода десятичной записи дроби 1/n.

19.06.2011, 12:21. Показов 9879. Ответов 6
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Здравствуйте, помогите пожалуста решить задачу на с++...
Дано натуральное число n > 1. Определить длину периода десятичной
записи дроби 1/n.
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
19.06.2011, 12:21
Ответы с готовыми решениями:

Определить длину периода десятичной записи дроби 1/n
1)Из заданого числа вычли сумму его чисел. Из результата вычли ещё раз сумму его цифр и т. д.Сколько таких действий надо сделать чтоб...

Дано натуральное число n > 1. Определить длину периода десятичной записи дроби 1/n
Задача уже обсуждалась на форуме, но тут вопрос скорее в другом. Итак сама задача: Дано натуральное число n > 1. Определить длину...

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

6
S9
Волшебник
 Аватар для S9
656 / 259 / 88
Регистрация: 18.12.2010
Сообщений: 545
19.06.2011, 14:00
Решение есть здесь, правда в Паскале.
Я его перевел в С++ как мог (вроде компилируется и выдает некий результат)
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
/*Период дроби равен периоду в последовательности остатков 
(докажите это; в частности, надо доказать, что он не может быть меньше). 
Кроме того, в этой последовательности все периодически повторяющиеся все члены различны, 
а предпериод имеет длину не более n. Поэтому достаточно найти (n+1)-ый член последовательности 
остатков и затем минимальное k, при котором (n+1+k)-ый член совпадает с (n+1)-ым.*/
#include <iostream.h>
 
int main(int argc, char * argv)
{
  int l = 0, r = 1;
  int c, n, k;
  cout << "Please enter n" << endl;
  cin >> n;
  //инвариант: r/n = результат отбрасывания l знаков в 1/n
  while(l != n + 1)
  {
    r = (10 * r) % n;
    l++;
  }
  c = r;
  //c = (n+1)-ый член последовательности остатков
  r = (10 * r) % n;
  k = 0;
  //r = (n+k+1)-ый член последовательности остатков
  while (r != c)
  {
    r = (10 * r) % n;
    k++;
  }
  cout << "Max period " << k << endl;
  cin.get();
}
0
5 / 0 / 0
Регистрация: 25.08.2010
Сообщений: 11
19.06.2011, 22:01  [ТС]
S9, большое спасибо конешно за помощь...но она не работает....т.е не правильно считает..
если кто сможет подправить буду очень благодарен...

Добавлено через 2 часа 14 минут
Цитата Сообщение от S9 Посмотреть сообщение
Решение есть здесь, правда в Паскале.
Я его перевел в С++ как мог (вроде компилируется и выдает некий результат)
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
/*Период дроби равен периоду в последовательности остатков 
(докажите это; в частности, надо доказать, что он не может быть меньше). 
Кроме того, в этой последовательности все периодически повторяющиеся все члены различны, 
а предпериод имеет длину не более n. Поэтому достаточно найти (n+1)-ый член последовательности 
остатков и затем минимальное k, при котором (n+1+k)-ый член совпадает с (n+1)-ым.*/
#include <iostream.h>
 
int main(int argc, char * argv)
{
  int l = 0, r = 1;
  int c, n, k;
  cout << "Please enter n" << endl;
  cin >> n;
  //инвариант: r/n = результат отбрасывания l знаков в 1/n
  while(l != n + 1)
  {
    r = (10 * r) % n;
    l++;
  }
  c = r;
  //c = (n+1)-ый член последовательности остатков
  r = (10 * r) % n;
  k = 0;
  //r = (n+k+1)-ый член последовательности остатков
  while (r != c)
  {
    r = (10 * r) % n;
    k++;
  }
  cout << "Max period " << k << endl;
  cin.get();
}

прога выводит 0 когда n=8
должна выводить: 3 т.к. 1/8=0,125
0
S9
Волшебник
 Аватар для S9
656 / 259 / 88
Регистрация: 18.12.2010
Сообщений: 545
19.06.2011, 22:19
Цитата Сообщение от xagxag Посмотреть сообщение
прога выводит 0 когда n=8
должна выводить: 3 т.к. 1/8=0,125
должно быть не 3 а 1, т.к. задание определить длину периода десятичной дроби.
ошибка у меня в том, что k в строке 23 надо присвоить 1
например 1/28 = 0,0357142857142857 правильный ответ 6
Code Скопировано
1
2
3
0,0357142857142857
      ^----^
        тут 6 знаков
а если выводит 1, то это значит что периода дроби нет (при n = 8 дробь тоже не периодичная)
0
298 / 298 / 150
Регистрация: 07.05.2011
Сообщений: 592
19.06.2011, 22:24
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
38
39
40
41
42
43
#include <iostream>
#include <cstdlib>
// Дано натуральное число N. Определить длину периода 1/n.
// Период дроби равен периоду в последовательности остатков.
// G++/Code::Blocks
// Сергей Бендер (Pascal), 28.12.2009
// lamed, RFPRO.Ru , 19.06.2011
using namespace std;
int main()
{
    int n,i,j;
    int r;
    int a;
    int ost[255];
 
    cin >> n;
    r=10;
    cout<<"0.";
    while (r<n)
    {
        r*=10;
        cout<<"0";
    }
 
    i=-1;
    do
    {
        i++;
        cout << r/n;
        r%=n;
        ost[i]=r;
        r*=10;
        j=1;
 
        while (ost[j]!=ost[i])
            j++;
    } while (j>=i);
    cout << endl;
    cout << i-j<<endl;
    system("pause");
 
    return 0;
}
0
viel
06.12.2011, 00:28
а можно полную программу для Pascal? я просто С++ не проходила и полностью программу с правильным выполнением не получается сделать
S9
Волшебник
 Аватар для S9
656 / 259 / 88
Регистрация: 18.12.2010
Сообщений: 545
06.12.2011, 01:49
Цитата Сообщение от S9 Посмотреть сообщение
Решение есть здесь, правда в Паскале.
См. пост 2
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
06.12.2011, 01:49
Помогаю со студенческими работами здесь

Дано натуральное число N. Определить длину периода 1/n
Дано натуральное число N. Определить длину периода 1/n. Период дроби равен периоду в последовательности остатков.

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

Определить длину периода десятичной дроби, используя функцию
дано натуральное число n&gt;1. определить длину периода десятичной дроби, используя функцию. Помогите переделать. сама задача: var...

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

Дано натуральное число: найдите число десятков в его десятичной записи
Дано натуральное число. Найдите число десятков в его десятичной записи (то есть вторую справа цифру его десятичной записи). При вычислениях...


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

Или воспользуйтесь поиском по форуму:
7
Ответ Создать тему
Новые блоги и статьи
Управление зависимостями в Python с Poetry
py-thonny 04.04.2025
Стандартный инструмент для установки пакетов в Python - pip - прекрасно справляется с базовыми сценариями: установил пакет командой pip install и используешь его. Но что произойдёт, когда разные. . .
Мониторинг с Prometheus в PHP
Jason-Webb 04.04.2025
Prometheus выделяется среди других систем мониторинга своим подходом к сбору и хранению метрик. В отличие от New Relic, который использует агентный подход и отправляет данные во внешнее хранилище,. . .
Пакет Context в Golang: Управление потоками и ресурсами
golander 04.04.2025
Работа с горутинами в Go часто напоминает управление непослушными детьми - они разбегаются кто куда, делают что хотят и не всегда завершаются вовремя. К счастью, в Go 1. 7 появился пакет context,. . .
Контейнеризация React приложений с Docker
Reangularity 03.04.2025
Контейнеризация позволяет упаковать приложение со всеми его зависимостями в автономный контейнер, который можно запустить на любой платформе с установленным Docker. Это существенно упрощает процессы. . .
Свой попап в SwiftUI
mobDevWorks 03.04.2025
SwiftUI, как декларативный фреймворк от Apple, предоставляет множество инструментов для создания пользовательских интерфейсов. В нашем распоряжении есть такие API как alerts, popovers, action sheets. . .
Антипаттерны микросервисной архитектуры
ArchitectMsa 03.04.2025
Хорошо спроектированная микросервисная система может выдержать испытание временем, оставаясь гибкой, масштабируемой и устойчивой к большинству проблем. Такая архитектура обладает высоким уровнем. . .
std::mutex в C++: Советы и примеры использования
bytestream 03.04.2025
std::mutex - это механизм взаимного исключения, который гарантирует, что критический участок кода выполняется только одним потоком в каждый момент времени. Это простое, но могущественное средство. . .
Не удержался от оценки концепции двигателя Стирлинга.
Hrethgir 03.04.2025
Сколько не пытался - она выдавала правильные схемы, причём случайно рисовала горячие области в середине, холодные по краям, трубки с краёв в низ и магнит в соединяющей, но при этой выдавала описание. . .
Метод с двумя буферами (или double buffering) или ping-pong buffering
Hrethgir 02.04.2025
Из ответов LM модели. Метод, который предполагает использование двух массивов для хранения промежуточных результатов сложения векторов, обычно применяется в сценариях, где необходимо минимизировать. . .
На любовном киберфронте
Alexander-7 01.04.2025
Недавно на одном малоизвестном сайте знакомств мною заинтересовалась девушка: «Текст немного странный. Но, судя по адресу почты, иностранка», – подумал я. Поколебавшись пару суток, я ответил ей:. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru
Выделить код Копировать код Сохранить код Нормальный размер Увеличенный размер