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

Перевод отрицательных чисел в двоичную систему счисления

11.08.2024, 19:16. Показов 687. Ответов 5
Метки си (Все метки)

Author24 — интернет-сервис помощи студентам
Здравствуйте! Помогите реализовать в программе ниже, чтобы она также переводила отрицательное число в двоичную систему счисления.

файл main.cpp
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
#define _CRT_SECURE_NO_WARNINGS
#include <stdio.h>
#include "my_lab.h"
 
int main() {
    char str[100];
 
    printf("Enter the number: ");
    scanf("%s", str);
 
    long num = str_to_long(str);
    if (num == 0) {
        printf("Error.\n");
    }
    else {
        printf("The number in 10: %ld\n", num);
    }
    if (num > 0) {
        printf("The number in 2: ");
        dec_to_bin(num);
    }
    else {
        printf("The number in 2: ");
        dec_to_bin(num-1);
    }
    return 0;
}
файл my_lab.cpp
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
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
#include "my_lab.h"
 
long str_to_long(const char* str) {
    long result = 0;
    int base = 10;
    int is_negative = 0;
    int my_num[] = {0, 0};
 
    // Обработать отрицательные числа
    if (*str == '-') {
        is_negative = 1;
        str++;
    }
 
    // Определить основание числа
    if (*str == '0') {
        str++;
        if (*str == 'x' || *str == 'X') {
            base = 16;
            str++;
        }
        else if (*str >= '0' && *str <= '7') {
            base = 8;
        }
    }
 
    // Преобразовать строку в число
    while (*str) {
        int digit;
        if (*str >= '0' && *str <= '9') {
            digit = *str - '0';
        }
        else if (*str >= 'a' && *str <= 'f') {
            digit = *str - 'a' + 10;
        }
        else if (*str >= 'A' && *str <= 'F') {
            digit = *str - 'A' + 10;
        }
        else {
            return 0;  // Недопустимый символ
        }
        if (digit >= base) {
            return 0;  // Недопустимая цифра для данного основания
        }
        if (result > (2147483647 - digit) / base) {
            return 0;
        }
        result = result * base + digit;
        str++;
    }
 
    if (result > 2147483647 || result < -2147483648) {
        return 0;
    }
 
    if (is_negative) {
        result = -result;
    }
    my_num[0] += result;
 
    return result;
}
 
void dec_to_bin(long num) {
    if (num > 1) {
        dec_to_bin(num / 2);
    }
    printf("%ld", num % 2);
}
файл my_lab.h
C
1
2
3
4
5
6
7
8
9
10
11
#pragma once
#ifndef MY_LAB_H
#define MY_LAB_H
 
#include <stdio.h>
#include <stdlib.h>
 
long str_to_long(const char* str);
void dec_to_bin(long num);
 
#endif
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
11.08.2024, 19:16
Ответы с готовыми решениями:

Перевод чисел в двоичную систему счисления
Хелпаните с задачей. в одномерном массиве чисел целого типа (16 бит) выполнить следующую двоичную...

Перевод отрицательных float в двоичную систему с побитовыми сдвигами
Добрый день! Мой код выдает ошибку при вводе отрицательных малых вещественных чисел -0,1; -0,01;...

Перевод чисел из 10 системы счисления в двоичную
Есть такая программа. Она перевод из 10-ой системы в 2-ую, что надо тут поменять, что бы переводила...

Программа для перевода дробных чисел из шестнадцатеричной в двоичную систему счисления
Здравствуйте, не могу понять как должен выглядеть код для выше упомянутой программы. И можно ли...

5
Вездепух
Эксперт CЭксперт С++
12805 / 6679 / 1798
Регистрация: 18.10.2014
Сообщений: 16,911
11.08.2024, 19:37 2
Цитата Сообщение от dangeka Посмотреть сообщение
C
1
2
3
4
5
6
void dec_to_bin(long num) {
    if (num > 1) {
        dec_to_bin(num / 2);
    }
    printf("%ld", num % 2);
}
C
1
2
3
4
5
6
7
void dec_to_bin(long num) {
  if (num < 0) {
    printf("-");
    num = -num;
  }
  if (num > 1) {
    ...
Цитата Сообщение от dangeka Посмотреть сообщение
C
23
24
        printf("The number in 2: ");
        dec_to_bin(num-1);
Так а что это такое? Что здесь делает некое num-1? С чего это вдруг вычитается единица?

Цитата Сообщение от dangeka Посмотреть сообщение
C
11
12
13
14
    long num = str_to_long(str);
    if (num == 0) {
        printf("Error.\n");
    }
А здесь что происходит? А что если 0 - это и есть правильный результат?

Цитата Сообщение от dangeka Посмотреть сообщение
C
42
43
44
        if (digit >= base) {
            return 0;  // Недопустимая цифра для данного основания
        }
А что если в этом месте окажется digit < 0? Это "допустимая цифра для данного основания"?

Цитата Сообщение от dangeka Посмотреть сообщение
C
52
53
54
    if (result > 2147483647 || result < -2147483648) {
        return 0;
    }
Так а что это за диапазон такой? Откуда взялись такие пределы?

Более того, судя по косвенным признакам, программа писалась для платформы MSVC. Но в MSVC тип long является 32-битным. То есть переменная long result никак не может выйти за эти пределы. В чем тогда смысл этой проверки?

Цитата Сообщение от dangeka Посмотреть сообщение
C
1
2
3
4
5
        // Определить основание числа
         ...
        else if (*str >= '0' && *str <= '7') {
            base = 8;
        }
   
Если вашей задачей было воспроизвести синтаксис констант языка С, то здесь это сделано не совсем точно. В языке С 09 - это синтаксическая ошибка. А у вас это будет считаться десятичной константой.
0
1 / 1 / 0
Регистрация: 11.11.2023
Сообщений: 20
11.08.2024, 20:22  [ТС] 3
тут, чтобы перевести из отрицательного числа, нужно сначала перевести это же число, но положительное, потом поменять 1 на 0 или 0 на 1, а затем прибавить 1. вот эту схему я не понимаю как реализовать

Добавлено через 57 секунд
num-1 это я пытался как-то реализовать схему перевода, которую я описал выше, но она неправильная

Добавлено через 3 минуты
C
1
2
3
4
    long num = str_to_long(str);
    if (num == 0) {
        printf("Error.\n");
    }
тут идет проверка, что введенное число находиться в промежутке чисел типа long. соответственно, если число не входит в промежуток, то функция выводит 0
0
Вездепух
Эксперт CЭксперт С++
12805 / 6679 / 1798
Регистрация: 18.10.2014
Сообщений: 16,911
11.08.2024, 20:27 4
Цитата Сообщение от dangeka Посмотреть сообщение
тут, чтобы перевести из отрицательного числа, нужно сначала перевести это же число, но положительное, потом поменять 1 на 0 или 0 на 1, а затем прибавить 1. вот эту схему я не понимаю как реализовать
Так откуда взялась такая странная схема?

Вы ясно написали в задании, что вам нужно "перевести отрицательное число в двоичную систему счисления". В любой системе счисления традиционные правила записи отрицательных чисел одинаковы: пишем знак -, а затем просто записываем абсолютное значение числа. Например, -510 - это -1012.

Вот и все. Никаких "поменять 1 на 0 или 0 на 1, а затем прибавить 1" не нужно.

Цитата Сообщение от dangeka Посмотреть сообщение
тут идет проверка, что введенное число находиться в промежутке чисел типа long. соответственно, если число не входит в промежуток, то функция выводит 0
Еще раз повторяю свой вопрос: а что если исходное число и так было 0?
1
1612 / 1514 / 251
Регистрация: 19.02.2010
Сообщений: 4,083
12.08.2024, 09:29 5
Цитата Сообщение от TheCalligrapher Посмотреть сообщение
Так откуда взялась такая странная схема?
https://ru.wikipedia.org/wiki/Дополнительный_код
ТСу по заданию, видимо, нужно именно компутерное (аппаратное) представление в доп.коде - а не двоичная СС в вакууме.


Цитата Сообщение от dangeka Посмотреть сообщение
чтобы перевести из отрицательного числа, нужно сначала перевести это же число, но положительное, потом поменять 1 на 0 или 0 на 1, а затем прибавить 1. вот эту схему я не понимаю как реализовать
На указанной странице педивикии есть пример кода сишной функции.
В общем, не надо отдельной операцией превращать отрицательное число в положительное - оператор инверсии битов инвертирует (в данном случае - превратит 1 в 0) и знаковый бит тоже.
0
Вездепух
Эксперт CЭксперт С++
12805 / 6679 / 1798
Регистрация: 18.10.2014
Сообщений: 16,911
12.08.2024, 09:32 6
Цитата Сообщение от VTsaregorodtsev Посмотреть сообщение
ТСу по заданию, видимо, нужно именно компутерное (аппаратное) представление в доп.коде - а не двоичная СС в вакууме.
Это будет представление отрицательных чисел в дополнительном коде. Но у ТС в задании ничего подобного не сказано. У ТС сказано "чтобы она также переводила отрицательное число в двоичную систему счисления". Никакого дополнительного кода тут даже отдалено не упоминается.
1
12.08.2024, 09:32
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
12.08.2024, 09:32
Помогаю со студенческими работами здесь

Перевод больших чисел в двоичную систему без массива
Нужно перевести число -10^9&lt;n&lt;10^9 в двоичную систему, массивы и строки использовать нельзя, даже с...

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

Перевод чисел в восьмеричную систему счисления
ввести число не большее 500. вывести представление этого числа в восьмеричной системе счисления

Перевод чисел из четверичной в десятичную систему счисления
Помогите, пожалуйста, с программой перевода целой и дробовой части числа из четверичной в десятинну...

Перевод чисел из десятичной в пятеричную систему счисления
Помогите

Перевод целых неотрицательных чисел с десятичной системы счисления в двоичную систему счисления
Перевод целых неотрицательных чисел с десятичной системы счисления в двоичную систему счисления.

Перевод целых положительных чисел из десятичной системы счисления в двоичную систему счисления
Помогите, пожалуйста, реализовать данную задачу: &quot;Перевод целых положительных чисел из десятичной...


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

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Новые блоги и статьи
Что такое хорошо и что такое плохо, вид сбоку. Индивид и общество - грань не нарушения.
Hrethgir 18.01.2025
В моей личной жизни и времени, я рассуждаю категорией "хуже-лучше", в том плане, когда меня спросили например - "а зачем ты делаешь свой процессор?", то я ответил - "чтобы сделать свою жизнь лучше". . .
Передача по ссылке или по значению в Java?
InfoMaster 18.01.2025
В мире программирования на Java одним из ключевых аспектов, требующих глубокого понимания, является механизм передачи параметров в методы. Этот фундаментальный концепт часто становится источником. . .
Тернарный условный оператор в Python
InfoMaster 18.01.2025
В мире программирования существует множество инструментов и конструкций, позволяющих создавать эффективный и лаконичный код. Одним из таких инструментов является тернарный условный оператор, который. . .
Как удалить неотслеживаемые файлы из рабочего дерева Git
InfoMaster 18.01.2025
В процессе разработки программного обеспечения с использованием системы контроля версий Git часто возникает необходимость в управлении неотслеживаемыми файлами. Неотслеживаемые файлы (untracked. . .
Что делает код if __name__ == "__main__": в Python
InfoMaster 18.01.2025
В мире программирования на Python существует множество важных концепций, и одной из наиболее интересных является конструкция if __name__ == "__main__". Эта специальная конструкция играет ключевую. . .
Как заставить Git забыть об отслеживаемом файле, добавленном в .gitignore
InfoMaster 18.01.2025
В мире разработки программного обеспечения система контроля версий Git стала неотъемлемой частью рабочего процесса, позволяя эффективно отслеживать изменения в коде и управлять ими. Однако. . .
Что означает use strict в JavaScript и для чего используется
InfoMaster 18.01.2025
В мире современной веб-разработки JavaScript играет ключевую роль как один из основных языков программирования. По мере его эволюции возникла необходимость в механизмах, которые помогли бы. . .
Как работать со скрытыми (hidden) элементами в jQuery
InfoMaster 18.01.2025
В современной веб-разработке управление видимостью элементов на странице является одним из ключевых аспектов создания интерактивных пользовательских интерфейсов. jQuery предоставляет мощный набор. . .
Как переключаться между ветками (Branch) с помощью checkout в Git
InfoMaster 18.01.2025
Ветки в Git являются одной из ключевых концепций для управления версионностью кода, позволяя разработчикам эффективно работать в команде и параллельно развивать программные проекты. Каждый новый. . .
Что такое стек и куча, чем они отличаются и где находятся
InfoMaster 18.01.2025
Понимание основных концепций памяти в программировании В мире современного программирования эффективное управление памятью играет ключевую роль в создании производительных и надежных приложений. . . .
Как использовать комментарии в JSON
InfoMaster 18.01.2025
JSON (JavaScript Object Notation) представляет собой легкий и широко используемый формат обмена данными, который стал стандартом де-факто для веб-приложений и программных интерфейсов. При работе с. . .
Как заставить git pull перезаписать локальные файлы в Git
InfoMaster 18.01.2025
Проблема перезаписи локальных файлов в Git При работе с системой контроля версий Git разработчики часто сталкиваются с ситуацией, когда необходимо синхронизировать локальный репозиторий с. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru