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

hex vs base64 - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Задача про дроби http://www.cyberforum.ru/cpp-beginners/thread1083559.html
Сделал вроде всё правильно, но задача не работает и выдаёт ошибку на компиляции: 1> Для всех выходных данных обновления не требуется. 1> drobi.cpp 1>d:\microsoft vusual studio 2010\vc\include\ostream(604): error C2248: std::basic_ios<_Elem,_Traits>::basic_ios: невозможно обратиться к private член, объявленному в классе "std::basic_ios<_Elem,_Traits>" 1> with 1> 1> ...
C++ Для чего функции поместили в "тип данных"? Вопрос про функции. Для чего функции поместили в "тип данных"? http://www.cyberforum.ru/cpp-beginners/thread1083537.html
C++ Распознание кода
typedef signed char aalSBool; const aalSBool AAL_SFALSE(-1); long SND_SPELL_SLOW_DOWN_END(AAL_SFALSE); SND_SPELL_SLOW_DOWN_END = aalCreateSample("magic_spell_slow_down_end.wav"); SND_SPELL_SLOW_DOWN_END = AAL_SFALSE; В первой строке определение синонима типа, а что дальше? 2-ая и 3-я строки похожи на прототипы функций, но у них нет определения.
C++ Работа со структурами
Помогите написать программу подобного рода: Работа со структурами. Программа должна содержать функции, необходимые для выполнения поставленной задачи. Задача:Даны сведения о 16 автомобилях: марка, номер и фамилия владельца. Определить фамилию владельца и марку по номеру. Сведения: Reno AK 6592 KK Мендус Mersedes AK 6593 KK Сизко BMV AK 6594 KK Андреев...
C++ Дано список записей с полями:фамилия ученика и дата рождения. Найти тех которые родились зимой http://www.cyberforum.ru/cpp-beginners/thread1083504.html
Помогите пожалуйста, задачу надо сдать через пол часа!!! Заранее спасибо
C++ В матрице найти максимальный и минимальный элемент,переставить строки в которых они находится Здравствуйте уважаемые форумчане. Я столкнулся с проблемой вот такой: Разработайте программу обработки массивов. Входные данные введите с клавиатуры. Результаты работы программы отобразите на экране. Я только учусь так что еще пока все плохо. Матрица размером N*N Не могу понять как в матрице найти максимальный и минимальный элемент,переставить строки в которых они находится и если они в одной... подробнее

Показать сообщение отдельно
Torument
0 / 0 / 1
Регистрация: 13.03.2014
Сообщений: 16
14.03.2014, 18:43     hex vs base64
Base64 туда и обратно:

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
70
void base64_encode(char *out, char *data, unsigned int len) 
{
   char *base64_set = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/";  
   unsigned char index2,index3;
   int i=0;
   for(; i<len; (i+=3,data+=3,out+=4)) 
   { 
      *out = base64_set[*data >> 2];     
      index2 = (*data << 4) & 0x30;
      if(i+2<len) 
      {         
         index2 |= *(data+1) >> 4;        
         index3 = ((*(data+1) << 4) & 0xFF) >> 2;
         if(i+3<len) 
         {            
            index3 |= *(data+2) >> 6;            
            *(out + 3) = base64_set[*(data+2) & 0x3F];
         } 
         else 
         {           
            *(out + 3) = '=';
         }
         *(out + 2) = base64_set[index3];
      } 
      else 
      {
         *(out + 2) = '=';
         *(out + 3) = '=';
      }
      *(out + 1) = base64_set[index2];
   }
   *out = 0;
}
 
char index2byte(char index) 
{  
   if(index >= 0x41 && index <= 0x5A) return index-0x41;
   if(index >= 0x61 && index <= 0x7A) return index-0x61+26;
   if(index >= 0x30 && index <= 0x39) return index-0x30+52;
   if(index == 0x2B) return 62;
   if(index == 0x2F) return 63;
   return 0;
}
 
unsigned int base64_decode(char *out, char *data, unsigned int len) 
{  
   char byte1,byte2,byte3,index2,index3;  
   unsigned int count = 0;
   for(;len--;data+=4)
   { 
      count+=3;      
      byte1 = (index2byte(*data) << 2) & 0xFF;
      index2 = index2byte(*(data+1));     
      byte1 |= index2 >> 4;
      if(*(data+2) != '=') 
      {
         byte2 = (index2 & 0xF) << 4;         
         index3 = index2byte(*(data+2));
         byte2 |= index3 >> 2;
         if(*(data+3) != '=') {
            byte3 = (index3 << 6) & 0xFF;
            byte3 |= index2byte(*(data+3));
         } else {count--;byte3=0;len=0;}
      } else {count-=2;byte2=byte3=0;len=0;}
      *out++ = byte1;
      *out++ = byte2;
      *out++ = byte3;
   }
   return count;
}
Но работает только с кириллицей
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru