Перевести целое число из одной системы счисления в другую, используя рекурсию - C (СИ)

Узнай цену своей работы

Формулировка задачи:

Вот есть задание "Перевести целое число из одной системы счисления в другую", которое находится в разделе Основы рекурсии. Я сделал программу, которая просто переводит из 10-ой в 2-ую систему счисления, но я вообще не представляю, как тут (да и зачем) использовать рекурсии. Код:
Листинг программы
  1. #include <stdio.h>
  2. int main(void)
  3. {
  4. int dec;
  5. int v;
  6. scanf_s("%d", &dec);
  7. v = 128;
  8. for (int i = 1; i <= 8; i++)
  9. {
  10. if (dec >= v)
  11. {
  12. printf("1");
  13. dec -= v;
  14. }
  15. else
  16. printf("0");
  17. v /= 2;
  18. }
  19. puts("\n\n");
  20. return 0;
  21. }

Решение задачи: «Перевести целое число из одной системы счисления в другую, используя рекурсию»

textual
Листинг программы
  1. char * uint2bin(unsigned n, char * buf) {
  2.     char * tail = ( n > 1 ) ? uint2bin(n >> 1, buf) : buf;   // <<
  3.     sprintf(tail, "%d", n & 1);
  4.    
  5.     return tail + 1;
  6. }

Объяснение кода листинга программы

В данном коде представлена функция uint2bin, которая принимает два аргумента: целое число n и указатель на буфер buf. Функция переворачивает число n из десятичной системы счисления в двоичную систему счисления и записывает результат в буфер buf. Внутри функции используется рекурсия для деления числа n на 2. Если число больше 1, то функция вызывает саму себя с аргументами n >> 1 (что означает деление n на 2) и buf. Если число равно 1, то функция просто возвращает буфер buf. Далее функция использует функцию sprintf для записи в буфер tail остатка от деления n на 2 в десятичной системе счисления. В конце функция возвращает указатель на следующую позицию в буфере, увеличенную на 1, чтобы вызов функции мог продолжить запись следующего разряда числа.

ИИ поможет Вам:


  • решить любую задачу по программированию
  • объяснить код
  • расставить комментарии в коде
  • и т.д
Попробуйте бесплатно

Оцени полезность:

6   голосов , оценка 4 из 5

Нужна аналогичная работа?

Оформи быстрый заказ и узнай стоимость

Бесплатно
Оформите заказ и авторы начнут откликаться уже через 10 минут
Похожие ответы