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

Как разобраться с рекурсией ?

01.12.2020, 14:09. Показов 1505. Ответов 3

Студворк — интернет-сервис помощи студентам
Добрый день, появилась проблема с заданием. Рекурсия очень плохо легла и в ютубе или же на форумах я тоже ничего подходящего не нашел. Вот такое задание было: Найти сумму чисел от от числа, являющегося порядковым номером студента в списке группы (12), до числа, вводимого с клавиатуры. Нельзя использовать оператор деления, циклы_.

Вот что я написал, но оно всегда уходит в Stack overflow.
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
static int Summa(int n)
        {
            int num = 12;
            int b = 0;
            if (n == num)
                return 0;
            if (n > num)
            {
                b = n - 1;
                return Summa(n) + b;
            }
            else
            {
                b = n + 1;
                return Summa(n) + b;
            }
    }
        static void Main(string[] args)
        {
            int n;
            Console.WriteLine("Введите число:");
            n = int.Parse(Console.ReadLine());
            Console.WriteLine(Summa(n));
        }
0
Лучшие ответы (1)
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
01.12.2020, 14:09
Ответы с готовыми решениями:

Не могу разобраться с рекурсией
Суть такова, что есть массив matrix. По краям у которого стоят единички. Нужно рекурсивно заполнить его двойками, не выходя за единички....

не могу разобраться рекурсией)
Напишите программу, которая запрашивает число и показатель степени. Напишите рекурсивную функцию, которая возводит число в степень путем...

Не могу разобраться с рекурсией
def factorial(x): def iter(prod, counter): if counter > x: return prod else: return iter(counter*prod,counter+1) ...

3
 Аватар для JustinTime
964 / 582 / 268
Регистрация: 20.12.2016
Сообщений: 1,506
01.12.2020, 14:33
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
static int Sum(int current, int max)
{
    return (current == max) ? max : current + Sum(++current, max);
}
 
static void Main(string[] args)
{
     int n;
     Console.WriteLine("Введите число:");
     n = int.Parse(Console.ReadLine());
     var min = Math.Min(12, n);
     var max = Math.Max(12, n);
     Console.WriteLine(Sum(min, max));
}
1
 Аватар для Enifan
1849 / 1191 / 501
Регистрация: 14.10.2018
Сообщений: 3,211
01.12.2020, 14:37
Лучший ответ Сообщение было отмечено LunST как решение

Решение

Цитата Сообщение от LunST Посмотреть сообщение
Stack overflow
Значение n остается неизменным. Когда вызываете Summa(n) делайте n-1 и n + 1
Логику не рассматривал
1
0 / 0 / 0
Регистрация: 01.12.2020
Сообщений: 7
01.12.2020, 14:52  [ТС]
Спасибо большое, действительно не заметил.

Добавлено через 2 минуты
Там к сожалению нельзя использовать деление. Но все равно спасибо, может кому-то пригодится.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
01.12.2020, 14:52
Помогаю со студенческими работами здесь

Помогите разобраться с рекурсией...
Здравствуйте, нашел решение задачи "ханойских башен", проблема с пониманием. <...> tn(n,1,2,3); <...> ...

Разобраться с рекурсией: stack overflow
#include<iostream> #include<vector> #include<string> #include<math.h> #include<cmath> #include<algorithm> using namespace std; ...

Как работает программа с рекурсией?
Где можно почитать как работает программа с рекурсией в pascal ? , желательно с объяснение каждой строки кода

Как нарисовать орнамент с рекурсией?
Помогите пожалуйста нарисовать данный рисунок с помощью рекурсивный процедуры.

Как подписать комментарии и разобраться с работой кода? Дали задание разобраться и объяснить, а я совсем новичок
using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; using System.Drawing; using...


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
Программный отбор элементов справочника Номенклатура по группе 1С
Maks 22.03.2026
Установка программного отбора элементов справочника "Номенклатура" из модуля формы документа. В качестве фильтра для отбора справочника служит группа номенклатуры. Отбор под наименованию группы (на. . .
Как я обхитрил таблицу Word
Alexander-7 21.03.2026
Когда мигает курсор у внешнего края таблицы, и нам надо перейти на новую строку, а при нажатии Enter создается новый ряд таблицы с ячейками, то мы вместо нервных нажатий Энтеров мы пишем любые буквы. . .
Krabik - рыболовный бот для WoW 3.3.5a
AmbA 21.03.2026
без регистрации и смс. Это не торговля, приложение не содержит рекламы. Выполняет свою непосредственную задачу - автоматизацию рыбалки в WoW - и ничего более. Однако если админы будут против -. . .
Программный отбор элементов справочника Сотрудники по перечислениям 1С
Maks 21.03.2026
Установка программного отбора элементов справочника "Сотрудники" из модуля формы документа. В качестве фильтра для отбора служит предопределенное значение перечислений. Процедура. . .
Переходник USB-CAN-GPIO
Eddy_Em 20.03.2026
Достаточно давно на работе возникла необходимость в переходнике CAN-USB с гальваноразвязкой, оный и был разработан. Однако, все меня терзала совесть, что аж 48-ногий МК используется так тупо: просто. . .
Оттенки серого
Argus19 18.03.2026
Оттенки серого Нашёл в интернете 3 прекрасных модуля: Модуль класса открытия диалога открытия/ сохранения файла на Win32 API; Модуль класса быстрого перекодирования цветного изображения в оттенки. . .
SDL3 для Desktop (MinGW): Рисуем цветные прямоугольники с помощью рисовальщика SDL3 на Си и C++
8Observer8 17.03.2026
Содержание блога Финальные проекты на Си и на C++: finish-rectangles-sdl3-c. zip finish-rectangles-sdl3-cpp. zip
Символические и жёсткие ссылки в Linux.
algri14 15.03.2026
Существует два типа ссылок — символические и жёсткие. Ссылка в Linux — это запись в каталоге, которая может указывать либо на inode «файла-ИСТОЧНИКА», тогда это будет «жёсткая ссылка» (hard link),. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru