Форум программистов, компьютерный форум CyberForum.ru

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
протест
0 / 0 / 0
Регистрация: 18.04.2011
Сообщений: 20
#1

Некурсивная функция - C++

23.04.2011, 22:48. Просмотров 302. Ответов 4
Метки нет (Все метки)

требуется помощь умных людей)

Над разработать нерекурсивную функцию (сама функция для натуральных заданых чисел N и M должна возвращать их наибольший общий делитель) и которая сокращает дробь вида a/b

заранее спасибо за помощь)
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
23.04.2011, 22:48     Некурсивная функция
Посмотрите здесь:

Функция удаления текста в скобках [2], непосредственно функция + 12кб вложений - C++
Доброго времени суток, случилось так, что пришлось работать с с-строками (лаба, угу), в которой нужно удалить весь текст в скобках,...

Перегрузка операций: friend-функция или функция-член класса - C++
Здравствуйте, меня интересует вопрос, в чем разница при перегрузке операторов через operator и friend. Вот к примеру такой код. class...

Функция sqrt: существует более одного экземпляра. Функция перегруженная - C++
#include <iostream> #include <math.h> #include <iomanip> using namespace std; int main(){ float s, p; int c, a; s=0; ...

Выясните, сохраняет ли булева функция 0, 1, является ли функция линейной, монотонной, само двойственной? - Дискретная математика
Помогите пожалуйста!!! Булева функция задана вектором значений F(x)=(1001) Выясните, сохраняет ли эта функция 0, 1, является ли эта...

какую библиотеку надо подключать чтоб работала функция _getch() и функция cin.get() - C++
какую библиотеку надо подключать чтоб работала функция _getch() и функция cin.get()

Функция - Pos(s,s1). Назначение - поиск первого вхождения подстроки s1 в строку s (аналогичная функция C - strstr) - C (СИ)
Функция - Pos(s,s1). Назначение - поиск первого вхождения подстроки s1 в строку s (аналогичная функция C - strstr).Помогите плииз

Функция нахождения всех суффиксов списка и функция mapIfMy - Haskell
Добрый день. Пожалуйста, помогите решить 2 задачи: 1. Напишите функцию tails:: ->], находящую все суффиксы заданного списка. Например...

Функция нахождения максимума в строке матрицы и функция вычисления ||D|| - Pascal
Помогите написать программу. Заранее спасибо. Даны вещественные матрицы A, B, C размером 5x6. Вычислить величину ...

что за функция такая strstr? или это не функция? - C++
void search(sp *list){ sp *prt = list; char f,r; cout<<Rus("введите текст")<<endl; cin>>f; cout<<Rus("введите выходной...

Процедура и функция: Функция определения максимальной цифры числа - Pascal
напишите программу,которая с помощью функции определяющей максимальную цифру числа выводит на экран наибольшую из цифр заданных...


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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
silent_1991
Эксперт С++
4958 / 3034 / 149
Регистрация: 11.11.2009
Сообщений: 7,027
Завершенные тесты: 1
23.04.2011, 23:26     Некурсивная функция #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
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
#include <iostream>
 
typedef long long ll_t;
 
struct Fraction
{
    ll_t m_num;
    ll_t m_den;
 
    Fraction(ll_t num, ll_t den):
    m_num(num),
    m_den(den)
    {
        if (m_den < 0)
        {
            m_num *= -1;
            m_den *= -1;
        }
    }
};
 
ll_t gcd(ll_t, ll_t);
Fraction reduce(Fraction);
 
int main()
{
    Fraction frac1(15, -18);
 
    Fraction frac2 = reduce(frac1);
 
    std::cout << frac1.m_num << "/" << frac1.m_den << " == " << frac2.m_num << "/" << frac2.m_den << std::endl;
 
    return 0;
}
 
ll_t gcd(ll_t num1, ll_t num2)
{
    num1 = num1 > 0 ? num1 : -num1;
    num2 = num2 > 0 ? num2 : -num2;
 
    while (num1 > 0 && num2 > 0)
    {
        if (num1 > num2)
            num1 %= num2;
        else
            num2 %= num1;
    }
 
    return num1 + num2;
}
 
Fraction reduce(Fraction frac)
{
    ll_t d = gcd(frac.m_num, frac.m_den);
 
    return Fraction (frac.m_num / d, frac.m_den / d);
}
протест
0 / 0 / 0
Регистрация: 18.04.2011
Сообщений: 20
23.04.2011, 23:30  [ТС]     Некурсивная функция #3
спасибо, щас буду проверять и понимать)
протест
0 / 0 / 0
Регистрация: 18.04.2011
Сообщений: 20
03.05.2011, 21:51  [ТС]     Некурсивная функция #4
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
#include "iostream"
using namespace std;
 
int NOD(int a, int b)
{
    if (a==b)
        return a;
    else
        if (a>b)
            return NOD(a-b,b);
        else
            if(b>a)
                return NOD(a,b-a);
}
int main()
{int a,b;
cout<<”vvedite a=;
    cin>>a;
cout<<vvedite b=;
    cin>>b;
cout<<a<</<<b<<endl;
    int nod=NOD(a,b);
    cout<<(a/nod)<</<<(b/nod)<<endl;
    return 0;
}
Добавлено через 15 секунд
вот как вариант
DexMipt
13 / 13 / 1
Регистрация: 13.03.2011
Сообщений: 98
03.05.2011, 22:03     Некурсивная функция #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
#include <stdio.h>
#define N 100
int NOD(int a, int b);
int main()
{
   int i,num, A[N];
   scanf("%d", &num);
 
 
   for(i=0;i<num;i++)
       scanf("%d", &A[i]);
 
   for(i=0;i<num;i++){
       A[i+1]=NOD(A[i],A[i+1]);
   }
 
    printf("%d", A[i-1]);
    return 0;
}
 
int NOD(int a, int b)
{
   int c ;
   c=a%b;
 
   while(c>0){
 
   a=b;
   b=c;
   c=a%b;
   }
   return b;
   }
Yandex
Объявления
03.05.2011, 22:03     Некурсивная функция
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru