Форум программистов, компьютерный форум CyberForum.ru

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

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Работа со структурами http://www.cyberforum.ru/cpp-beginners/thread184942.html
#include<iostream.h> #include<math.h> struct List { float fi,r,z; int n; }; void vvod (List &, int); void vivod (List &);
C++ Видеоуроки по с++ Всем привет, просьба дать прямую ссылку на бесплатные видеокурсы по с++ для начинающих, заранее большое спасибо. http://www.cyberforum.ru/cpp-beginners/thread184940.html
Работа с классами и объектами C++
Создать класс для работы с тригонометрическими комплексными числами. Комплексное число в тригонометрической форме задается своим модулем r и аргументом (углом) φ в виде r×. Данные класса: модуль r и аргумент φ. Открытые функции класса: ввод числа (r и φ), вывод числа на экран в форме r×, возведение комплексного числа в степень. При возведении комплексного числа в целую степень, модуль возводится...
Найти произведение цифр числа C++
ВВести с клавиатуры целое двух значное число. найти произведение цифр числа.
C++ Найти корни уравнения http://www.cyberforum.ru/cpp-beginners/thread184925.html
Написать программу, которая находит корни уравнения e^x=x+2 с погрешностью 10^-10. Заранее благодарен.
C++ Рекуррентные соотношения Добрый день! Имеется такая задачка: Провести вычисления по рекуррентным формулам: во вложениях текст задания. Может кто сталкивался с задачами такого типа. подробнее

Показать сообщение отдельно
RUSya82
236 / 114 / 3
Регистрация: 15.10.2010
Сообщений: 395
01.11.2010, 22:10
Занят был.
Короче вот как то так:
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] становится равным нулю, и цикл разрывается.
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru