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

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

Войти
Регистрация
Восстановить пароль
 
 
Рейтинг: Рейтинг темы: голосов - 24, средняя оценка - 4.75
Юлек
4 / 3 / 0
Регистрация: 26.10.2009
Сообщений: 43
#1

Найти 1+2+3+...+n рекурсивно и итеративно - C++

30.08.2010, 22:29. Просмотров 3087. Ответов 54
Метки нет (Все метки)

Уважаемые программисты!!! помогите разобраться, дали задачу. Найти 1+2+3+...+n.
Первый способ, решить рекурсивно, а второй не рекурсивно. Чем текст программ будет различаться???
0
Лучшие ответы (1)
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
30.08.2010, 22:29
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Найти 1+2+3+...+n рекурсивно и итеративно (C++):

Вычислить выражение рекурсивно и итеративно - C++
Помогите записать пример. Решить задачу на фото двумя способами - с применением рекурсии и без неё. ...

Вычисление цепной дроби (рекурсивно и итеративно) - C++
Как это вообще сделать ??? Нужно с помощь. рекурсии и без неё С++.

Вычислить произведение рекурсивно/итеративно, оценить время выполнения - C++
Нужно разработать программу с использованием рекурсивной функции и без использования рекурсивной функции. Оценит время выполнения. x=...

Найти рекурсивно сумму ряда - C++
e^(-x^2) = сумма, где k от 0 до бесконечности (-1)^k * (x^2*k)/k! x от 1 до 15 Пользуйтесь редактором формул внизу страницы ...

Найти рекурсивно значение функции Аккермана A(m, n) - C++
Я новичек так что сильно не бейте :) Нужно рекурсивно найти функцию Аккермана. double Akerrman(int m,int n) { if (m = 0) return...

Найти минимальный элемент массива рекурсивно - C++
Всем привет!!! Нужно найти минимальный элемент массива при помощи рекурсии. Просидел вчера весь день и никак не могу воткнуть как...

Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
NightmareZ
1340 / 563 / 37
Регистрация: 31.03.2009
Сообщений: 1,919
30.08.2010, 23:03 #16
Цитата Сообщение от Юлек Посмотреть сообщение
в смысле метопрограмма???
Это значит, что программа описывает то, как будет написана программа.... ну т.е. программа, в результате работы которой получится другая программа.... Вон те шаблоны, которые я написал, развернутся во время компиляции и в готовой программе получим лишь константу.
2
Юлек
4 / 3 / 0
Регистрация: 26.10.2009
Сообщений: 43
30.08.2010, 23:11  [ТС] #17
Цитата Сообщение от Lavroff Посмотреть сообщение
Юлек, От нуля было бы корректнее) Ибо сумма 0 не есть 1)
Метапрограмма - с использованием шаблонов.
но к сожалению без компьютера писали и поэтому конечно напортачила!!!! в спс за исправления!!!!

Добавлено через 6 минут
Цитата Сообщение от Lavroff Посмотреть сообщение
C++
1
return (i==0)?0:(i>1)?i+sum(i-1):i;

что это значит??
0
ForEveR
В астрале
Эксперт С++
7972 / 4734 / 321
Регистрация: 24.06.2010
Сообщений: 10,541
Завершенные тесты: 3
30.08.2010, 23:13 #18
Юлек, Тернарный оператор. Если i=0, вернуть 0, иначе если i>1 начать рекурсию, если не больше одного вернуть i. По сути как-то так) Правда отрицательные числа не предусмотренны как я понимаю.
1
Юлек
4 / 3 / 0
Регистрация: 26.10.2009
Сообщений: 43
30.08.2010, 23:14  [ТС] #19
а как эту прогу на си переделать????
0
ForEveR
В астрале
Эксперт С++
7972 / 4734 / 321
Регистрация: 24.06.2010
Сообщений: 10,541
Завершенные тесты: 3
30.08.2010, 23:15 #20
Юлек, Убрать cout. написать printf("%d", Sum(5)); Подключить stdio.h
1
Юлек
4 / 3 / 0
Регистрация: 26.10.2009
Сообщений: 43
30.08.2010, 23:17  [ТС] #21
что в моей ужасной программе надо изменить чтобы она работала???

Добавлено через 56 секунд
а то на экзамене я ее написала, и по ней надо отчитываться!!!!((((
0
bobromet
24 / 24 / 1
Регистрация: 06.03.2010
Сообщений: 59
30.08.2010, 23:26 #22
s = 0 сделать
1
#pragma
Временно недоступен
952 / 223 / 6
Регистрация: 12.04.2009
Сообщений: 921
30.08.2010, 23:27 #23
NightmareZ, интуитивно понятный код,но почему используется Sum<>::value? то есть почему там значёк разрешения видимости? получается,там какой-то безымянный и бестипный value(ну это ещё понятно-вроде как член enum-а) в безымянном enum-е? или это какая-то стандартная часть нового стандарта и value это некое стандартное имя чего-то?
1
ForEveR
В астрале
Эксперт С++
7972 / 4734 / 321
Регистрация: 24.06.2010
Сообщений: 10,541
Завершенные тесты: 3
30.08.2010, 23:31 #24
Юлек, Отрицательные числа вводить не рекомендуется

C
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
#include <stdio.h>
 
int main()
{
   int n=0, s=0, i=0;
   printf("Enter n: ");
   scanf("%d", &n);
   for(i=0; i<=n; ++i)
   {
      s+=i;
   }
   printf("\n");
   printf("%d", s);
   return 0;
}
Ну и рекурсию в догонку.

C
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
#include <stdio.h>
 
int Sum(int n)
{
   if(n==0) 
      return 0;
  else if(n==1)
      return 1;
  else
     return n+Sum(n-1);
}
 
int main()
{
   int n, res=0;
   printf("Enter n: ");
   scanf("%d", &n);
   res=Sum(n);
   printf("\n");
   printf("%d", res);
   return 0;
}
1
Юлек
4 / 3 / 0
Регистрация: 26.10.2009
Сообщений: 43
30.08.2010, 23:34  [ТС] #25
а как ее сделать не рекурсивной???

последний вопрос!!! больше не буду приставать!!!
0
ForEveR
В астрале
Эксперт С++
7972 / 4734 / 321
Регистрация: 24.06.2010
Сообщений: 10,541
Завершенные тесты: 3
30.08.2010, 23:40 #26
Юлек, А смысл рекурсивную функцию делать не рекурсивной? оО

Ну как-то так:

C
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
#include <stdio.h>
 
int Sum(int n)
{
   int i, int s=0;
   for(i=0; i<n; ++i)
   {
      s+=i;
   }
   return s;
}
 
int main()
{
   int n, res=0;
   printf("Enter n: ");
   scanf("%d", &n);
   res=Sum(n);
   printf("\n");
   printf("%d", res);
   return 0;
}
1
Юлек
4 / 3 / 0
Регистрация: 26.10.2009
Сообщений: 43
30.08.2010, 23:41  [ТС] #27
Огромное спасибо за помощь!!!!
0
NightmareZ
1340 / 563 / 37
Регистрация: 31.03.2009
Сообщений: 1,919
30.08.2010, 23:43 #28
Цитата Сообщение от #pragma Посмотреть сообщение
интуитивно понятный код,но почему используется Sum<>::value? то есть почему там значёк разрешения видимости?
Ну какбэ потому что value объявлен в Sum

Цитата Сообщение от #pragma Посмотреть сообщение
получается,там какой-то безымянный и бестипный value(ну это ещё понятно-вроде как член enum-а) в безымянном enum-е?
Ну потому что просто так объявить в структуре поле можно, но нельзя ему задать значение. А в enum можно задать значение для это поля при конкретном N.

Цитата Сообщение от #pragma Посмотреть сообщение
или это какая-то стандартная часть нового стандарта и value это некое стандартное имя чего-то?
Нет. Вместо value можешь задать любое допустимое для идентификатора имя.
1
bobromet
24 / 24 / 1
Регистрация: 06.03.2010
Сообщений: 59
30.08.2010, 23:53 #29
Цитата Сообщение от Lavroff Посмотреть сообщение

Ну как-то так:

C
1
2
3
4
5
6
7
8
9
int Sum(int n)
{
   int i, int s=0;
   for(i=0; i<n; ++i)
   {
      s+=i;
   }
   return s;
}
в цикле нужно сделать i<=n а не i<n , а то при n = 5 получится 10
2
ForEveR
В астрале
Эксперт С++
7972 / 4734 / 321
Регистрация: 24.06.2010
Сообщений: 10,541
Завершенные тесты: 3
30.08.2010, 23:56 #30
bobromet, Гм. Да. ОписАлся
0
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
30.08.2010, 23:56
Привет! Вот еще темы с ответами:

Рекурсивно найти число входящих элементов Е в дерево Т - C++
Почему-то не работает, помогите! :C struct gruz_p // Описание записи о грузополучателе { char nomer, fio, dr, pol, ...

Рекурсивно найти сумму нечетных элементов до заданного n - C++
Добрый вечер! Необходимо рекурсивно найти сумму нечетных элементов до заданного n, даже не знаю с чего начать!...

Рекурсивно найти n-ую производную для заданого x. Результат похож на шестнадцатеричный код - C++
Задание:рекурсивно найти n-ую производную f(x)={e}^{(a{x}^{2}+bx+c)} для заданого x,построив для {f}^{(n)}(x) рекурентное соотношение. ...

Рекурсивно обчислити добуток n ≥ 2 співмножників (n парне): у = (2/1)*(2/3)*(4/3)*(4/5)*(6/5)*(6/7).Рекурсивно обчислити добуток n ≥ 2 співмножників - C++
Рекурсивно обчислити добуток n ≥ 2 співмножників (n парне): у = (2/1)*(2/3)*(4/3)*(4/5)*(6/5)*(6/7)...


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

Или воспользуйтесь поиском по форуму:
Yandex
Объявления
30.08.2010, 23:56
Ответ Создать тему
Опции темы

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