Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Карта форума Темы раздела Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.55/114: Рейтинг темы: голосов - 114, средняя оценка - 4.55
2 / 2 / 0
Регистрация: 23.10.2010
Сообщений: 111
1

Преобразование текст -> двоичный код -> текст

01.11.2010, 19:31. Показов 21055. Ответов 16
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
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
// praci5.cpp: определяет точку входа для консольного приложения.
//
 
#include "stdafx.h"
#include <stdio.h>
#include <conio.h>
 
int main()
{
     printf( "Vvod stroki: " );
     char s[255];
     scanf( "%[^\n]s" , s );
 
 printf( "'%s' Preobrazovanie v binarny kod: " , s );
        int i,c,power;
 
     for( i=0 ; s[i]!='\0' ; i++ )
     {
          c = s[i];
          for( power=7 ; power+1 ; power-- )
          if( c >= (1<<power) )
          {
              c -= (1<<power); 
              printf("1");
          }
 
          else
          printf("0");
   } getch();
         
          char bin = s[i];
         int dec = 0;
                  printf("\nResult = %c", dec);
         for(i = 0; bin != 0; ++i)
 
        {
                int j = bin % 10;
                bin /= 10;
                if(j)
                        dec += j << i;
                                 
        }
       
getch();
}
Вроде все правильно. Ошибки не вылазиют, но результат не тот, что надо. При вводе текста преобразуется в двоичный а обратно в текст нет.
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
01.11.2010, 19:31
Ответы с готовыми решениями:

Текст в двоичный код
Подскажите, как преобразовать текст в двоичный код, при этом с работающими пробелами? Т.е. при...

Перевести двоичный код в текст
Добрый день! Мне нужно перевести двоичный код из txt файла в текст на c# Нашел один метод,...

Превратить звук в двоичный код а затем -- в текст
Привет народ. Поставлена задача -- есть источник аналогового звука с частотой 300 герц. Источник...

Преобразование в двоичный код С.
Задание следующее: Написать программу, которая получает случайное целое типа int,выводит...

16
242 / 120 / 14
Регистрация: 15.10.2010
Сообщений: 395
01.11.2010, 20:12 2
В строке 31 переменная char bin = s[i] становится равной = '\0'. посмотрите, ведь условием выхода из предыдущего цикла for было именно пока s[i]!='\0'.

Добавлено через 3 минуты
последний цикл for просто не выполняется, так как bin != 0 - false


Добавлено через 2 минуты
В - третьих: что вы собрались преобразовывать обратно, если преобразованную в двоичный код строку, вы вывели на экран, но нигде не сохранили?
0
2 / 2 / 0
Регистрация: 23.10.2010
Сообщений: 111
01.11.2010, 20:20  [ТС] 3
В строке 31 переменная char bin = s[i] становится равной = '\0'. посмотрите, ведь условием выхода из предыдущего цикла for было именно пока s[i]!='\0'.

Добавлено через 3 минуты
последний цикл for просто не выполняется, так как bin != 0 - false
ну правильно, s[i] не равно нулю и bin также не равно нулю.

Добавлено через 1 минуту
В - третьих: что вы собрались преобразовывать обратно, если преобразованную в двоичный код строку, вы вывели на экран, но нигде не сохранили?
на счет этого я что то не подумал. что предлагаете? Изучать начал недавно.
0
242 / 120 / 14
Регистрация: 15.10.2010
Сообщений: 395
01.11.2010, 20:34 4
Давайте поэкспериментируем, поставьте оператор printf("\nResult = %c", dec);
из строки 33 внутрь цикла вот так
C++
1
2
3
4
5
6
7
8
for(i = 0; bin != 0; ++i)
     {
        int j = bin % 10;
        bin /= 10;
        if(j)
           dec += j << i;
        printf("\nResult = %c", dec);                        
     }
То есть если в конце выполнения программы Вы увидите Result =, то цикл сделал, хотя бы одну итерацию. Если нет, то нет.

Добавлено через 11 секунд

Добавлено через 3 минуты
Ничего не пойму, почему мои сообщения по два раза выводятся???

Короче как 0, так и '\0' - возвращают false. То есть цикл не выполняется. Можете так проверить
C++
1
2
3
4
5
6
7
8
9
10
11
12
#include <iostream>
#include <conio.h>
 
using namespace std;
 
int main()
{
    if('\0')
    cout << "NULL\n";
    getch();
    return 0;
    }
0
2 / 2 / 0
Регистрация: 23.10.2010
Сообщений: 111
01.11.2010, 20:36  [ТС] 5
C++
1
2
3
4
5
6
7
8
9
10
  char bin = s[i];
         int dec = 0;
          printf("\nResult = %c", dec);
         for(i = 0; bin != 0; ++i)
 
        {
                int j = bin % 10;
                bin /= 10;
                if(j)
                        dec += j << i;
при таком вот положении у меня доходит до Result:

при
C++
1
2
3
4
5
6
7
for(i = 0; bin != 0; ++i)
     {
        int j = bin % 10;
        bin /= 10;
        if(j)
           dec += j << i;
        printf("\nResult = %c", dec);
выполняется только первый этап, Result нет
0
242 / 120 / 14
Регистрация: 15.10.2010
Сообщений: 395
01.11.2010, 20:37 6
Цитата Сообщение от isakz Посмотреть сообщение
В - третьих: что вы собрались преобразовывать обратно, если преобразованную в двоичный код строку, вы вывели на экран, но нигде не сохранили?
на счет этого я что то не подумал. что предлагаете? Изучать начал недавно.
Сохранять!!! В массив например. А потом считывать из него по 8 чисел и преобразовывать каждую в символ.

Добавлено через 13 секунд
Цитата Сообщение от isakz Посмотреть сообщение
В - третьих: что вы собрались преобразовывать обратно, если преобразованную в двоичный код строку, вы вывели на экран, но нигде не сохранили?
на счет этого я что то не подумал. что предлагаете? Изучать начал недавно.
Сохранять!!! В массив например. А потом считывать из него по 8 чисел и преобразовывать каждую в символ.
0
2 / 2 / 0
Регистрация: 23.10.2010
Сообщений: 111
01.11.2010, 20:45  [ТС] 7
Сохранять!!! В массив например. А потом считывать из него по 8 чисел и преобразовывать каждую в символ.
напишите пожалуйста как будет правильно это сделать. завтра надо. книгу читать время неосталось.
0
242 / 120 / 14
Регистрация: 15.10.2010
Сообщений: 395
01.11.2010, 20:47 8
Цитата Сообщение от isakz Посмотреть сообщение
при
Код C++
1
2
3
4
5
6
7
for(i = 0; bin != 0; ++i)
{
int j = bin % 10;
bin /= 10;
if(j)
dec += j << i;
printf("\nResult = %c", dec);
выполняется только первый этап, Result нет
Правильно, потому что '\0' = false.
0
2 / 2 / 0
Регистрация: 23.10.2010
Сообщений: 111
01.11.2010, 21:01  [ТС] 9
bin=s[i] при s[i]!='\0' и bin !='\0' все правильно же. что не так..
0
242 / 120 / 14
Регистрация: 15.10.2010
Сообщений: 395
01.11.2010, 21:06 10
можно попробовать

Добавлено через 2 минуты
Вы не поняли. Цикл for прерывается, когда s[i] становится равным нулю. Цикл прервался, но s[i] так и осталось быть равным нулю. Почитайте на досуге про циклы for
0
2 / 2 / 0
Регистрация: 23.10.2010
Сообщений: 111
01.11.2010, 21:52  [ТС] 11
bin=s[i] при s[i]!='\0' и bin !='\0' все правильно же. что не так.. это ничто не меняет
может дело в массиве. хотя я указал : char bin = s[i];

Добавлено через 24 минуты
всмысле вообще никакого действия не происходило что ли?

Добавлено через 1 минуту
при s[i] = 0

Добавлено через 15 минут
цикл for начался при i=0 заканчивается при s[i] != 0

Добавлено через 4 минуты
ошибка. начальное значение i=0 условие выполняется при s[i] != 0. но здесь s[i] и не равно нулю.
0
242 / 120 / 14
Регистрация: 15.10.2010
Сообщений: 395
01.11.2010, 22:10 12
Занят был.
Короче вот как то так:
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
// praci5.cpp: îïðåäåëÿåò òî÷êó âõîäà äëÿ êîíñîëüíîãî ïðèëîæåíèÿ.
//
 
//âàëï#include "stdafx.h"
#include <stdio.h>
#include <conio.h>
#include <iostream>
#include <string.h>
#include <cmath>
 
 
using namespace std;
 
int main()
{
     printf( "Vvod stroki: " );
     char s[255];
     int binary[2048];
     scanf( "%[^\n]s" , s );
     int n = strlen(s);
 
 printf( "'%s' Preobrazovanie v binarny kod: " , s );
        int i,c,power, a = 0,j;
 
     for( i=0 ; s[i]!='\0' ; i++ )
     {
          c = s[i];
          for( power=7 ; power+1 ; power--, a++ )
             if( c >= (1<<power) )
             {
                 c -= (1<<power); 
                 binary[a] = 1;
             }
          else{
             binary[a] = 0;}
     } 
     getch();
     //cout << "\na=" << a << endl;
     for(i=0;i<a;i++)
     cout << binary[i];
     cout << endl;
     char dec;
     i =0;            //printf("\nResult = %c", dec);
     while(1)
     {
        dec = 0;
        for(j=7; j>=0;j--)
        {
             dec += pow(2.0,(double)(j)) * binary[i];
             i++;
             //cout << endl << dec << endl;
        }    
        cout << dec;  
        if(i>a)
        break;              
     }
     getch();
     return 0;
}
Коряво, но работает. Можно сделать и лучше.

Добавлено через 8 минут
Цитата Сообщение от isakz Посмотреть сообщение
цикл for начался при i=0 заканчивается при s[i] != 0
Цикл продолжается, пока s[i] != 0. При очередной итерации s[i] становится равным нулю, и цикл разрывается.
1
2 / 2 / 0
Регистрация: 23.10.2010
Сообщений: 111
01.11.2010, 22:10  [ТС] 13
Спасибо. почему в конце d выскакивает, что то понять не смог, где это написано...
0
242 / 120 / 14
Регистрация: 15.10.2010
Сообщений: 395
01.11.2010, 22:22 14
isakz, Dev C++. В смысле, когда выводит последнюю строку, d выскакивает?

Добавлено через 2 минуты
В 55 строке i>=a
0
2 / 2 / 0
Регистрация: 23.10.2010
Сообщений: 111
01.11.2010, 22:28  [ТС] 15
работаю на Visual C++. примерно так:
Vvod stroki: g
'g' Preobrazovanie v binarny kod 01100111
gd
Добавлено через 2 минуты
Еще раз спасибо. Явно на новичка не похож.

Добавлено через 2 минуты
мне осталось только разобраться что почем. и все.
0
242 / 120 / 14
Регистрация: 15.10.2010
Сообщений: 395
01.11.2010, 22:55 16
ща, маленько поправил, комменты напишу и скину.

Добавлено через 13 минут
Ну короче вот:
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
// praci5.cpp: определяет точку входа для консольного приложения.
#include <stdio.h>
#include <conio.h>
#include <iostream>
#include <string.h>
#include <cmath>
#define POW(A,B) 
/*функция возведения в степень для работы
с int(стандартная функция pow(a,b) работает с double*/
int ipow(int a,int b)
{
    if (b>0)
    return a*ipow(a, b-1);
    else
    return 1;
}
 
using namespace std;
 
int main()
{
     printf( "Vvod stroki: " );
     char s[255];//для строки в обычном виде
     int binary[2048];//для строки в двоичном виде
     cin.getline(s, 2048);//ввод строки с клавиатуры
     //scanf( "%[^\n]s" , s );
     int n = strlen(s);//в n записываем длину введенной строки
     printf( "'%s' Preobrazovanie v binarny kod: " , s );
     int i,c,power, a = 0,j;
     for( i=0 ; i < n ; i++ )
     {
          c = s[i];
          for( power=7 ; power+1 ; power--, a++ )
             if( c >= (1<<power) )
             {
                 c -= (1<<power); 
                 binary[a] = 1;//выводим в массив
             }
          else{
             binary[a] = 0;}
     } 
     for(i=0;i<a;i++)
        cout << binary[i];//печать строки в двоичном виде
     cout << endl;//перенос строки
     char dec;
     i =0;            
     cout << "Обратно в символы: ";
     /*Дальше преобразовываем каждые 8 бит
     массива binary по отдельности в символ
     начиная со старшего бита
     например 2^7*binary[0] + 2^6*binary[1] + ... +2^0*binary[7]
     таким образом получаем первый символ и.т.д*/
     while(1)
     {
        dec = 0;
        for(j=7; j>=0;j--)//перебираем очередные 8 "бит"
        {
             dec += ipow(2,(j)) * binary[i];
             i++;
        }    
        cout << dec;  
        if(i>=a)//не забываем, что в a у нас остался размер двоичного массива
        break;              
     }
     getch();
     return 0;
}
У меня работает.

Добавлено через 6 минут
isakz, Спасибо за этот фрагмент:
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
for( i=0 ; s[i]!='\0' ; i++ )
     {
          c = s[i];
          for( power=7 ; power+1 ; power-- )
          if( c >= (1<<power) )
          {
              c -= (1<<power); 
              printf("1");
          }
 
          else
          printf("0");
   }
, где вы его взяли?
0
2 / 2 / 0
Регистрация: 23.10.2010
Сообщений: 111
01.11.2010, 23:21  [ТС] 17
на каком то фаруме англоязычном.

Добавлено через 22 минуты
вот ссылка если надо http://in.answers.yahoo.com/qu... 737AARsomv
0
01.11.2010, 23:21
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
01.11.2010, 23:21
Помогаю со студенческими работами здесь

Преобразование текста в двоичный код
Здравствуйте! Подскажите, как в Visual Studio C# преобразовать текст из richTextBox1.Text (типа...

Преобразование Букв в двоичный код
Вот надыбал такой код для сабжа #include &lt;iostream&gt; using namespace std; int main() { ...

Преобразование строки в двоичный код и обратно
Есть ли функция для преобразования строки которая содержится в переменной в двоичный код и обратно?...

Преобразование символов в двоичный код и обратно
unit Unit1; interface uses Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls,...


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

Или воспользуйтесь поиском по форуму:
17
Ответ Создать тему
Новые блоги и статьи
Как подключить JavaScript файл в другом JavaScript файле
InfoMaster 20.01.2025
В современной веб-разработке организация кодовой базы играет ключевую роль в создании масштабируемых и поддерживаемых приложений. Модульность и правильное структурирование кода стали неотъемлемыми. . .
Как откатить изменения в исходниках, не внесенные в Git
InfoMaster 20.01.2025
При работе с системой контроля версий Git разработчики часто сталкиваются с необходимостью отменить внесенные изменения в исходном коде. Особенно актуальной становится ситуация, когда изменения еще. . .
В чем разница между px, in, mm, pt, dip, dp, sp
InfoMaster 20.01.2025
В мире цифрового дизайна и разработки интерфейсов правильный выбор единиц измерения играет ключевую роль в создании качественного пользовательского опыта. История развития систем измерений для. . .
Как изменить адрес удалённого репозитория (origin) в Git
InfoMaster 20.01.2025
В терминологии Git термин origin является стандартным именем для основного удаленного репозитория, с которым взаимодействует локальная копия проекта. Когда разработчик клонирует репозиторий с. . .
Как переместить последние коммиты в новую ветку (branch) в Git
InfoMaster 20.01.2025
При работе над проектом часто возникают ситуации, когда необходимо изолировать определенные изменения от основной линии разработки. Это может быть связано с экспериментальными функциями, исправлением. . .
Как вернуть результат из асинхронной функции в JavaScript
InfoMaster 20.01.2025
Асинхронное программирование представляет собой фундаментальную концепцию в JavaScript, которая позволяет выполнять длительные операции без блокировки основного потока выполнения программы. В. . .
Какой локальный веб-сервер выбрать
InfoMaster 19.01.2025
В современной веб-разработке локальные веб-серверы играют ключевую роль, предоставляя разработчикам надежную среду для создания, тестирования и отладки веб-приложений без необходимости использования. . .
Почему планшеты и iPad уже не так популярны, как раньше
InfoMaster 19.01.2025
Эра революционных инноваций История планшетов началась задолго до того, как эти устройства стали привычными спутниками нашей повседневной жизни. В начале 1990-х годов появились первые прототипы,. . .
Как самому прошить BIOS ноутбука
InfoMaster 19.01.2025
BIOS (Basic Input/ Output System) представляет собой важнейший компонент любого компьютера или ноутбука, который обеспечивает базовое взаимодействие между аппаратным и программным обеспечением. . .
Какой Linux выбрать для домашнего компьютера
InfoMaster 19.01.2025
Современные реалии выбора операционной системы В современном мире выбор операционной системы для домашнего компьютера становится все более важным решением, которое может существенно повлиять на. . .
Как объединить два словаря одним выражением в Python
InfoMaster 19.01.2025
В мире программирования на Python работа со словарями является неотъемлемой частью разработки. Словари представляют собой мощный инструмент для хранения и обработки данных в формате "ключ-значение". . . .
Как без исключения проверить существование файла в Python
InfoMaster 19.01.2025
При разработке программного обеспечения на Python часто возникает необходимость проверить существование файла перед выполнением операций с ним. Это критически важная задача, которая помогает избежать. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru