5 / 0 / 0
Регистрация: 25.08.2010
Сообщений: 11
1

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

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

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

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

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

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

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

6
S9
Волшебник
656 / 259 / 88
Регистрация: 18.12.2010
Сообщений: 545
19.06.2011, 14:00 2
Решение есть здесь, правда в Паскале.
Я его перевел в С++ как мог (вроде компилируется и выдает некий результат)
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  [ТС] 3
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
Волшебник
656 / 259 / 88
Регистрация: 18.12.2010
Сообщений: 545
19.06.2011, 22:19 4
Цитата Сообщение от xagxag Посмотреть сообщение
прога выводит 0 когда n=8
должна выводить: 3 т.к. 1/8=0,125
должно быть не 3 а 1, т.к. задание определить длину периода десятичной дроби.
ошибка у меня в том, что k в строке 23 надо присвоить 1
например 1/28 = 0,0357142857142857 правильный ответ 6
Код
0,0357142857142857
      ^----^
        тут 6 знаков
а если выводит 1, то это значит что периода дроби нет (при n = 8 дробь тоже не периодичная)
0
298 / 298 / 150
Регистрация: 07.05.2011
Сообщений: 592
19.06.2011, 22:24 5
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 6
а можно полную программу для Pascal? я просто С++ не проходила и полностью программу с правильным выполнением не получается сделать
S9
Волшебник
656 / 259 / 88
Регистрация: 18.12.2010
Сообщений: 545
06.12.2011, 01:49 7
Цитата Сообщение от S9 Посмотреть сообщение
Решение есть здесь, правда в Паскале.
См. пост 2
0
06.12.2011, 01:49
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
06.12.2011, 01:49
Помогаю со студенческими работами здесь

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

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

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

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


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

Или воспользуйтесь поиском по форуму:
7
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2024, CyberForum.ru