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

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

05.07.2019, 11:25. Показов 1047. Ответов 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
19491 / 10097 / 2460
Регистрация: 30.01.2014
Сообщений: 17,805
05.07.2019, 12:14
Цитата Сообщение от smurf19458 Посмотреть сообщение
В чем может быть секрет?
Секрет в слове "неопределенное". Правильно работающая программа - это частный случай неопределенного поведения.
Первая программа некорректная, содержит неопределенное поведение из-за ошибки программиста (вас), и на вашем компьютере неопределенное поведение выражается ожидаемым для вас образом, а на другом компьютере выражается в виде краха программы. Неопределенное поведение поэтому и называется так, что мы не можете (у вас нет формальных оснований) предсказать поведение программы в общем случае.
1
Модератор
Эксперт С++
 Аватар для zss
13770 / 10963 / 6491
Регистрация: 18.12.2011
Сообщений: 29,240
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
Ответ Создать тему
Новые блоги и статьи
Модель микоризы: классовый агентный подход
anaschu 02.01.2026
Раньше это было два гриба и бактерия. Теперь три гриба, растение. И на уровне агентов добавится между грибами или бактериями взаимодействий. До того я пробовал подход через многомерные массивы,. . .
Учёным и волонтёрам проекта «Einstein@home» удалось обнаружить четыре гамма-лучевых пульсара в джете Млечного Пути
Programma_Boinc 01.01.2026
Учёным и волонтёрам проекта «Einstein@home» удалось обнаружить четыре гамма-лучевых пульсара в джете Млечного Пути Сочетание глобально распределённой вычислительной мощности и инновационных. . .
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
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-динозавры, а новое поколение лёгких потоков. Откат?. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru