Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.75/4: Рейтинг темы: голосов - 4, средняя оценка - 4.75
1 / 1 / 1
Регистрация: 01.03.2012
Сообщений: 19

Ошибка при рекурсивном вызове

07.07.2012, 12:35. Показов 917. Ответов 4
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
На третьем вызове функции вылазит ошибка об отсутсвии инциализации переменой j, дебаг говорит, что после второго захода в функци j внезапно становится равно незивестному какому-то числу. Как исправить?
"printf("\nФУНКЦИЯ НАЧАЛАСЬ");" это еще со стаорогов ырианта, когда я отлавливал другой баг, не обращайте внимания.
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
#include <conio.h>
#include <stdio.h>
#include <iostream>
#include <clocale>
 
using namespace std;
 
void sort( int *A, int N, int p, int q)
{
    int i,j,r,T,h;
    if (p<q) 
    {
        printf("\nФУНКЦИЯ НАЧАЛАСЬ");
        r=*(A+p);
        i=p-1;
        j=q+1;
        printf("\nФУНКЦИЯ НАЧАЛАСЬ2");
        while (i<j)
        {
            do {i=i+1;} while (A[i]<r);
            do {j=j-1;} while (A[i]<r);
            if (i<j)
            {
                printf("\nФУНКЦИЯ НАЧАЛАСЬ3");
                T=A[i];
                A[i]=A[j];
                A[j]=T;
            } 
        } 
    }
    printf("\nФУНКЦИЯ НАЧАЛАСЬ4\n");
    sort(A, N, *(A+p), j);
    sort(A, N, *(A+j+1), q);
}
 
 
void main()
{
    setlocale (LC_CTYPE, "rus");
    int B[]={5, 0, 3, 1, 4, 8};
    int N;
    N=sizeof(B)/sizeof(B[0]);
    sort(B, N, 0, 5);
    for (int o=0; o<=5; o++)
    {
        printf("a[%d]= %d\n", o, B[o]);
    }
     _getch();
}
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
07.07.2012, 12:35
Ответы с готовыми решениями:

Посчитать количество итераций при рекурсивном вызове функции
void hoarSort(int* arrPtr, int first_element, int last_element, int lenght_array, int etheration) { int i = first_element, j =...

Как передать целочисленный параметр в функцию по ссылке при рекурсивном вызове?
void consonant_count(trie*root,trie*parent,int amount_of_consonant,bool found,int *c) { ...

Ошибка при вызове деструктора (при вызове delete в деструкторе)
Не могу найти ошибку, при вызове деструктора от класса, который был создан при помощи конструктора с параметром const String &amp;,...

4
DU
1500 / 1146 / 165
Регистрация: 05.12.2011
Сообщений: 2,279
07.07.2012, 14:38
если условие из 11 строчки не выполнится, то j останется не инициализированной.
0
1 / 1 / 1
Регистрация: 01.03.2012
Сообщений: 19
07.07.2012, 15:40  [ТС]
Цитата Сообщение от DU Посмотреть сообщение
если условие из 11 строчки не выполнится, то j останется не инициализированной.
Я это знаю, вот и спрашиваю, как исправить эту ситуацию. И почему она не инициализирована, ведь на предыдущих заходах в функцию ей было прсвоено значение.
0
59 / 59 / 8
Регистрация: 29.06.2012
Сообщений: 188
07.07.2012, 16:11
Цитата Сообщение от Dobbos Посмотреть сообщение
Я это знаю, вот и спрашиваю, как исправить эту ситуацию. И почему она не инициализирована, ведь на предыдущих заходах в функцию ей было прсвоено значение.
написать до условия чему должна равнятся j . j - это локальная переменная в этой функции, это значит, что когда функция завершится, она удалится, и в новом вызове это будет новая j. Тогда нужно либо это j передавать как параметр, или объявлять глобальной
0
1 / 1 / 1
Регистрация: 01.03.2012
Сообщений: 19
07.07.2012, 16:16  [ТС]
О, пасиба, понял как сделать, сейчас наваю.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
07.07.2012, 16:16
Помогаю со студенческими работами здесь

Ошибка при рекурсивном вычислении: "недопустимая операция с плавающей точкой"
double kor(double a) { double x=0.5*(1+a); if (fabs(x-a)&gt;0.0001) return x=0.5*(kor(a-1)+a/kor(a-1)); } void __fastcall...

Ошибка при вызове метода класса, при чтении из файла
добрый день, пытаюсь считать данные из и запихнуть их в список в файле у меня вот такие данные a01 b10 А и Б надо запихнуть в...

Ошибка в рекурсивном шаблоне функции
Добавлено через 9 минут template &lt;int from,int much&gt; int getRangeSum(){ return from+getRangeSum&lt;from+1,much-1&gt;(); }; template...

Ошибка при вызове метода
Не пойму в чем ошибка... #include &lt;vector&gt; #include &lt;iostream&gt; template &lt;typename T&gt; class Beast { public: int x; ...

Ошибка при вызове деструктора
Добрый вечер! Почему при вызове деструктора вылетает ошибка после компиляции кода? #include &lt;conio.h&gt; #include &lt;iostream&gt; ...


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

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод. Thinkpad X220 Tablet —. . .
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru