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

Рекурсия, какая разница между двумя вариантами кода?

05.07.2019, 11:25. Показов 1077. Ответов 7
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте, объясните разницу между приведенными ниже вариантами кода.
Первый вариант компилируется и успешно отрабатывает на моем компьютере, а в проверяющей
системе сайта acmp выдает Runtime Error. Второй же вариант работает и там и там. Где кроется подвох?
C++
1
2
3
4
5
6
int gcd(int a, int b)
{
    if ((a == 0) ^ (b == 0)) return std::max(a, b);
    if (b == 0) return a;
    gcd(b, a%b);
}
C++
1
2
3
4
5
6
int gcd(int a, int b)
{
    if ((a == 0) ^ (b == 0)) return std::max(a, b);
    if (b == 0) return a;
    return gcd(b, a%b);
}
Параметры компилятора проверяющей системы:
g++ -static -fno-strict-aliasing -DACMP -lm -s -x c++ -std=c++14 -Wl,--stack=67108864 -O2 -o task.exe task.cpp
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
05.07.2019, 11:25
Ответы с готовыми решениями:

Какая разница между двумя алгоритмами?
Вообщем, как только я свою задачу не упрощал, но в указанные ограничения она так и не входит. Сначала был лимит памяти, теперь лимит...

Какая Разница между сортировками?
Какая разница между сортировками, если в итоге все виды сортируют одинаково. Т е. Результат одинаковый

Какая разница между cin и scanf?
Здраствуйте. А какая разница между cin и scanf?

7
 Аватар для zayats80888
6352 / 3523 / 1428
Регистрация: 07.02.2019
Сообщений: 8,995
05.07.2019, 11:29
smurf19458, первый вариант UB, не возвращается значение при раскрутке стека
0
Заблокирован
05.07.2019, 11:30
1й чего возвращает в gcd(b, a%b);?
0
1 / 1 / 0
Регистрация: 10.12.2017
Сообщений: 48
05.07.2019, 11:40  [ТС]
В таком случае почему у меня на компьютере все работает? В чем может быть секрет?
0
Заблокирован
05.07.2019, 11:44
плюнуть, это работает кругом:
C++
1
2
3
4
5
6
7
8
9
10
int gcd(int a,int b)
{
    if(!b) return a;
    return gcd(b,a%b);
    //или так
    /*while (a && b)
        if (a > b) a %= b;
        else b %= a;
    return a+b;*/
}
0
611 / 416 / 151
Регистрация: 11.01.2019
Сообщений: 1,746
05.07.2019, 11:58
Цитата Сообщение от smurf19458 Посмотреть сообщение
if ((a == 0) ^ (b == 0))
Стесняюсь спросить, а что сие за зверь???
0
19500 / 10105 / 2461
Регистрация: 30.01.2014
Сообщений: 17,816
05.07.2019, 12:14
Цитата Сообщение от smurf19458 Посмотреть сообщение
В чем может быть секрет?
Секрет в слове "неопределенное". Правильно работающая программа - это частный случай неопределенного поведения.
Первая программа некорректная, содержит неопределенное поведение из-за ошибки программиста (вас), и на вашем компьютере неопределенное поведение выражается ожидаемым для вас образом, а на другом компьютере выражается в виде краха программы. Неопределенное поведение поэтому и называется так, что мы не можете (у вас нет формальных оснований) предсказать поведение программы в общем случае.
1
Модератор
Эксперт С++
 Аватар для zss
13773 / 10966 / 6491
Регистрация: 18.12.2011
Сообщений: 29,244
05.07.2019, 13:38
Цитата Сообщение от jugu Посмотреть сообщение
что сие за зверь?
А это кто-то захотел "изящно" написать
C++
1
if(a==0 && b!=0 || a!=0 && b==0 )
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
05.07.2019, 13:38
Помогаю со студенческими работами здесь

Какая разница между компиляцией и компоновкой?
только начал учить C++ и возник такой вопрос

Какая разница между аргументами и параметрами?
#include <iostream> using namespace std; //объявление функции int mystrlen(char *str); //В скобочках это параметр функции ? ...

Какая разница между cin и getline?
1) Какая разница между cin и getline? 2) Почему будет работать "string s=a+" "+b" (где а и b другие переменные типм sting), и не будет...

Разница между двумя идентичными программами
Объясните разницу между двумя абсолютно идентичными программами. Программа 1, в текстовом файле где записаны 10 слов, нужно поменять 1 ,...

Разница между двумя библиотеками потоков
В чем разница между стандартной библиотекой управления потоками <thread> и управлениями потоками через WinAPI?Преимущества и тд. Расскажите...


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

Или воспользуйтесь поиском по форуму:
8
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование . \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json> Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом. # Check if. . .
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так: https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347 Основана на STM32F303RBT6. На борту пять. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru