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

Расшифруйте пожалуйста код конвертера кодировок текста. Linux - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Бинарные файлы c++ http://www.cyberforum.ru/cpp-beginners/thread302191.html
Здравствуйте. Нужно в бинарный файл записать строку (нового стиля), единственное что известно, так это то, что в строке не более 16 символов. Подскажите, как можно преобразовать string в нужный char *str
C++ Сформировать массив из элементов матрицы С массива В m, n построить массив С, выполняя деление каждого элемента массива В на min элемент в столбце (С++). за ранние спасибо. http://www.cyberforum.ru/cpp-beginners/thread302175.html
C++ Хэш-таблица
Ребят, помогите, пожалуйста, решить задачу: Хэш-функция определена как h(k) = k mod 11. Вводится последовательность N натуральных чисел. Построить хэш-таблицу прямого доступа.
решить (массив в обратном порядке)! C++
Помогите с решением! Плиз, очень надо! 2) Даны целые массивы X, Y. Каждый массив преобразовать так, чтобы его компоненты располагались в обратном порядке, т.е. получить массивы: ={X,.....X}, Y={Y,...Y}, компоненты которых пронумерованы также от 0 до 9.
C++ Корректировка в рекурсии http://www.cyberforum.ru/cpp-beginners/thread302127.html
Возникла проблема в несложной задаче. Решать задачу конечно же не требуется, просто отккоректировать в плане рекурсии. Вот условие: http://********/index.asp?main=task&id_task=165 А вот мой код: #include <cstdlib> #include <iostream> using namespace std; int s(int a,int b);
C++ Вычислить коэфициент корреляции Известны зависимости тока ротора АД АИУМ225М4 от напряжения при различных коэфициентах нагрузки. Для зависимостей нагрузки 0.7 и 0.9 ( два данных графика, данные записаны как матрица в 6 столбцов и 2 строки! соответственно первая строка постоянная - напряжение, вторая - ток) вычислить коэфициент корреляции: методом наименьших квадратов подобрать зависимость вида I_2=a_0-a_1 U_1+a_2 U_1^2 ,... подробнее

Показать сообщение отдельно
ProofFy
Сообщений: n/a

Расшифруйте пожалуйста код конвертера кодировок текста. Linux - C++

22.05.2011, 20:13. Просмотров 573. Ответов 0
Метки (Все метки)

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
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
#include <iostream>
#include <fstream>
#include <string.h>
 
using namespace std;
 
int statisticArray[128];
 
//Matrix of converting
char ConvertMatrix[6][128]={
{   // KOI8-R ==> CP866
126,126,126,126,126,126,126,126,126,126,126,126,126,126,126,126,
126,126,126,126,126,126,126,126,126,126,127,126,120,126,122,126,
126,126,126,113,126,126,126,126,126,126,126,126,126,126,126,126,
126,126,126,112,126,126,126,126,126,126,126,126,126,126,126,  0,
110, 32, 33,102, 36, 37,100, 35,101, 40, 41, 42, 43, 44, 45, 46,
 47,111, 96, 97, 98, 99, 38, 34,108,107, 39,104,109,105,103,106,
 30,  0,  1, 22,  4,  5, 20,  3, 21,  8,  9, 10, 11, 12, 13, 14,
 15, 31, 16, 17, 18, 19,  6,  2, 28, 27,  7, 24, 29, 25, 23, 26},
{   // KOI8-R ==> CP1251
  0,  0,  0,  0,  0,  0,  0,  0,  0,  0,  0,  0,  0,  0,  0,  0,
  0,  0,  0,  0,  0,  0,  0,  0,  0,  0, 45,  0, 48,  0, 55,  0,
  0,  0,  0, 56,  0,  0,  0,  0,  0,  0,  0,  0,  0,  0,  0,  0,
  0,  0,  0, 40,  0,  0,  0,  0,  0,  0,  0,  0,  0,  0,  0, 41,
126, 96, 97,118,100,101,116, 99,117,104,105,106,107,108,109,110,
111,127,112,113,114,115,102, 98,124,123,103,120,125,121,119,122,
 94, 64, 65, 86, 68, 69, 84, 67, 85, 72, 73, 74, 75, 76, 77, 78,
 79, 95, 80, 81, 82, 83, 70, 66, 92, 91, 71, 88, 93, 89, 87, 90},
{   // CP866 ==> KOI8
 97, 98,119,103,100,101,118,122,105,106,107,108,109,110,111,112,
114,115,116,117,102,104, 99,126,123,125,127,121,120,124, 96,113,
 65, 66, 87, 71, 68, 69, 86, 90, 73, 74, 75, 76, 77, 78, 79, 80,
 62, 62, 62, 62, 62, 62, 62, 62, 62, 62, 62, 62, 62, 62, 62, 62,
 62, 62, 62, 62, 62, 62, 62, 62, 62, 62, 62, 62, 62, 62, 62, 62,
 62, 62, 62, 62, 62, 62, 62, 62, 62, 62, 62, 62, 62, 62, 62, 62,
 82, 83, 84, 85, 70, 72, 67, 94, 91, 93, 95, 89, 88, 92, 64, 81,
 51, 35,  0,  0,  0,  0,  0,  0, 28, 62, 30, 62,  0,  0, 62, 26},
{   // CP866 ==> CP1251
 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79,
 80, 81, 82, 83, 84, 85, 86, 87, 88, 89, 90, 91, 92, 93, 94, 95,
 96, 97, 98, 99,100,101,102,103,104,105,106,107,108,109,110,111,
  0,  0,  0,  0,  0,  0,  0,  0,  0,  0,  0,  0,  0,  0,  0,  0,
  0,  0,  0,  0,  0,  0,  0,  0,  0,  0,  0,  0,  0,  0,  0,  0,
  0,  0,  0,  0,  0,  0,  0,  0,  0,  0,  0,  0,  0,  0,  0,  0,
112,113,114,115,116,117,118,119,120,121,122,123,124,125,126,127,
 40, 56, 42, 58, 47, 63, 33, 34, 48,  0, 55,  0, 57, 36,  0, 45},
{   // CP1251 ==> KOI8
  0,  0,  0,  0,  0,  0,  0,  0,  0,  0,  0,  0,  0,  0,  0,  0,
  0,  0,  0,  0,  0,  0,  0,  0, 26,  0,  0,  0,  0,  0,  0,  0,
 26,  0,  0,  0,  0,  0,  0,  0, 51, 63,  0,  0,  0, 26,  0,  0,
 28,  0,  0,  0,  0,  0,  0, 30, 35,  0,  0,  0,  0,  0,  0,  0,
 97, 98,119,103,100,101,118,122,105,106,107,108,109,110,111,112,
114,115,116,117,102,104, 99,126,123,125,127,121,120,124, 96,113,
 65, 66, 87, 71, 68, 69, 86, 90, 73, 74, 75, 76, 77, 78, 79, 80,
 82, 83, 84, 85, 70, 72, 67, 94, 91, 93, 95, 89, 88, 92, 64, 81},
{   // CP1251 ==> CP866
  0,  0,  0,  0,  0,  0,  0,  0,  0,  0,  0,  0,  0,  0,  0,  0,
  0,  0,  0,  0,  0,  0,  0,  0,127,  0,  0,  0,  0,  0,  0,  0,
127,118,119,  0,125,  0,  0,  0,112,  0,114,  0,  0,127,  0,116,
120,  0,  0,  0,  0,  0,  0,122,113,124,115,  0,  0,  0,  0,117,
  0,  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,
 96, 97, 98, 99,100,101,102,103,104,105,106,107,108,109,110,111}};
 
 
 
 
int main(int argc, char**argv)
{
    string strTemp=argv[1];
    char Temp, chTemp;
    char codeNumber;
//  unsigned long int sizeOfFile(0);
//  Protected   
    if(argc==1)
    {
        cout << "Format Error!" << endl;
        cout << "Use this form (without ''):" << endl;
        cout << "'PROGRAMM_NAME' -'CODE' 'INPUT_FILE_NAME.txt' 'OUTPUT_FILE_NAME.txt'" << endl << endl;
        cout << "CODE: koi8-r or cp866 or cp1251" << endl;
        return 0;
    } 
    if((argc!=4)||((strTemp!="-koi8-r")&&(strTemp!="-cp1251")&&(strTemp!="-cp866")))
    {
        cout << "Format Error!" << endl;
        cout << "Use this form (without ''):" << endl;
        cout << "'PROGRAMM_NAME' -'CODE' 'INPUT_FILE_NAME.txt' 'OUTPUT_FILE_NAME.txt'" << endl << endl;
        cout << "CODE: koi8-r or cp866 or cp1251" << endl;
    } 
    else
    {
    //Statistic
    ifstream inStat(argv[2]);
    for(int i(0); i<=1000; i++)
    {
      Temp=inStat.get();
      if(int(Temp)>=0)
      {
        i--;
      }
      else
      {
        statisticArray[128+int(Temp)]++;
      }
    };
    inStat.close();
    chTemp=argv[1][3];
    if((statisticArray[5]+statisticArray[37])>(statisticArray[69]+statisticArray[101]))
    {
        cout << "Input code - cp866." << endl;
        switch(chTemp)              // input code - cp866
        {
        case 'i':   codeNumber=2;       // output code - koi8-r
                break;
        case '1':   codeNumber=3;       // output code - cp1251
                break;
        case '8':   codeNumber=6;       // output code - cp866
        }
    }
    else
        if((statisticArray[97]+statisticArray[65])>(statisticArray[64]+statisticArray[96])) 
        {
            cout << "Input code - koi8-r." << endl;
            switch(chTemp)          // input code - koi8-r
            {
            case 'i':   codeNumber=6;   // output code - koi8-r
                    break;
            case '1':   codeNumber=1;   // output code - cp1251
                    break;
            case '8':   codeNumber=0;   // output code - cp866
            }
        }
        else
        {
            cout << "Input code - cp1251." << endl;
            switch(chTemp)          // input code - cp1251
            {
            case 'i':   codeNumber=4;   // output code - koi8-r
                    break;
            case '1':   codeNumber=6;   // output code - cp1251
                    break;
            case '8':   codeNumber=5;   // output code - cp866
            }
        }
 
    if (codeNumber!=6)
    {
        ofstream out(argv[3]);
        ifstream in(argv[2]);
        unsigned long int sizeOfFile(0);
        in.seekg (0, std::ios::end);
        sizeOfFile = in.tellg();
        in.seekg (0, std::ios::beg);
        cout << "Text size: " << sizeOfFile << " symbols." << endl;
            if(!in)
            {
                cout << "Input file not find" << endl;
            }
            else
            {
                if(!out)
                {
                    cout << "Output file not find" << endl;
                }
                else
                {
                    for(unsigned long int i(0); i<sizeOfFile; i++)  // !in.eof()
                    {                       
                        Temp=in.get();
                        if (int(Temp)>=0)
                        out.put(Temp);
                        else
                        out.put(char(int(ConvertMatrix[codeNumber][128+int(Temp)])-128));
                    }
                };
            };
            
        }
        else
        {
            cout << "Converting is not required." << endl;
        };
    };
}
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 02:15. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru