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

Русский ввод - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Двумерные динамические массивы http://www.cyberforum.ru/cpp-beginners/thread111175.html
Проверить, является ли исходная матрица, составленная из целых чисел, нижней треугольной. Напечатать соответствующее сообщение.
C++ Класс контейнер - работа со строками Написал программу по следующему задание: Класс контейнер - абстракция текста, метод удаления одной, метод добавления строки, метод очистки текста, метод измерения самой длинной строки, метод вывода. Пишу в VS 2008 professional. У меня возникли две проблемы: 1. Из класса text мне нужно перенести метод string getMaxLenghtRow() в класс Row и реализовать его в файлик Row.cpp, но после переноса... http://www.cyberforum.ru/cpp-beginners/thread111152.html
Создать таблицу с записями о сотрудниках отдела C++
Help>> Написать и отладить программу решения задачи, сформулированной в варианте. В программе предусмотреть контрольный вывод вводимых данных и результатов в соответствии с поставленной задачей. Создать таблицу с записями о сотрудниках отдела. Записи имеют следующую структуру: Табельный номер - цифровое поле Шифр управления - цифровое поле Код отдела - цифровое поле ФИО -...
C++ Среднее арифметическое наибольшего и наименьшего значений матрицы
дана действительная матрица размером n*m найти среднее арифметическое ее наибольшего и наименьшего значений
C++ Определить функции: сумма цифр числа, вращение числа (цифры - в обратном порядке), деление чисел (результат - действительное число) http://www.cyberforum.ru/cpp-beginners/thread111131.html
Определить класс: целое число. Определить функции: сумма цифр числа, вращение числа (цифры - в обратном порядке), деление чисел (результат - действительное число).
C++ Создать таблицу с записями о принтерах Написать и отладить программу решения задачи, сформулированной в варианте. В программе предусмотреть контрольный вывод вводимых данных и результатов в соответствии с поставленной задачей. Вариант: . Создать таблицу с записями о принтерах. Записи содержат следующие данные: Фирма – символьное поле; Марка - символьное поле; Скорость печати - цифровое поле; Цена - цифровое... подробнее

Показать сообщение отдельно
Iworb
анимешник++
 Аватар для Iworb
93 / 60 / 2
Регистрация: 03.11.2009
Сообщений: 411
31.03.2010, 19:11     Русский ввод
Я вот недавно подучил STL и сделал с его помощью программу, реализация которой на обычном Си требовала бы немало усилий. Очень хочется усовершенствовать программу. Объясню суть. Программа работает с множествами. Получает буквы английского алфавита и работает с ними. Теперь сам вопрос: как заставить получать ее буквы русского алфавита и правильно понимать? В ASCII есть коды русских букв, НО - с клавиатуры я не знаю как их ввести. Если заполнять по ASCII коду, то в принципе это легко, но может кто знает, как заставить считывать русские буквы именно русскими, а не крякозябрами.
Код:
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
#include<conio.h>
#include<locale.h>
#include<vector>
#include<iostream>
#include<list>
using namespace std;
 
void print(vector<char> a)
{
    for(int i=0;i<a.size();i++) printf("%c ",a.at(i));
    cout<<endl<<"--------------------------------------------------------------------------------";
}
 
vector<char> universal(vector<char> a)
{
    vector<char> c; bool f;
    for(int i=0;i<a.size();i++)
    {
        f=true;
        for(int j=0;j<c.size();j++)if(a.at(i)==c.at(j)) f=false;
        if(f) c.push_back(a.at(i));
    }
    return c;
}
 
vector<char> fusion(vector<char> a, vector<char> b)
{
    vector<char> c;
    c=a;
    bool f=true;
    for(int i=0;i<b.size();i++)
    {
        f=true;
        {
            for(int j=0;j<a.size();j++)
            {
                if(b.at(i)==a.at(j))
                f=false;
            }
        }
        if(f) c.push_back(b.at(i));
    }
    return c;
}
 
vector<char> crossing(vector<char> a, vector<char> b)
{
    vector<char> c;
    bool f;
    for(int i=0;i<a.size();i++)
    {
        f=true;
        for(int j=0;j<b.size();j++) if(a.at(i)==b.at(j)) f=false;
        if(!f) c.push_back(a.at(i));
    }
    return c;
}
 
vector<char> margin(vector<char> a, vector<char> b)
{
    vector<char> c;
    bool f;
    for(int i=0;i<a.size();i++)
    {
        f=true;
        for(int j=0;j<b.size();j++) if(a.at(i)==b.at(j)) f=false;
        if(f) c.push_back(a.at(i));
    }
    return c;
}
 
vector<char> addition(vector<char> a, vector<char> I)
{
    vector<char> c;
    bool f;
    for(int i=0;i<I.size();i++)
    {
        f=true;
        for(int j=0;j<a.size();j++) if(I.at(i)==a.at(j)) f=false;
        if(f) c.push_back(I.at(i));
    }
    return c;
}
 
vector<char> sym_margin(vector<char> a, vector<char> b)
{
    vector<char> c;
    bool f;
    for(int i=0;i<a.size();i++)
    {
        f=true;
        for(int j=0;j<b.size();j++) if(a.at(i)==b.at(j)) f=false;
        if(f) c.push_back(a.at(i));
    }
    for(int i=0;i<b.size();i++)
    {
        f=true;
        for(int j=0;j<a.size();j++) if(b.at(i)==a.at(j)) f=false;
        if(f) c.push_back(b.at(i));
    }
    return c;
}
 
int main()
{
    setlocale(LC_ALL,"Russian");
    setlocale(LC_ALL,"");
    int lena, lenb, lenc, i, j;
    char ans;
    cout<<"Размер множества A:";
    scanf("%d",&lena);
    cout<<"Размер множества B:";
    scanf("%d",&lenb);
    cout<<"Размер множества C:";
    scanf("%d",&lenc);
    cout<<endl;
    vector<char> A(lena);
    vector<char> B(lenb);
    vector<char> C(lenc);
    printf("get A(not more than %d):",lena);
    for(i=0;i<lena;i++) scanf("%1s",&A.at(i));
    cout<<"\nМножество A:";
    A=universal(A);
    print(A);
    printf("get B(not more than %d):",lenb);
    for(i=0;i<lenb;i++) scanf("%1s",&B.at(i));
    cout<<"\nМножество B:";
    B=universal(B);
    print(B);
    printf("get C(not more than %d):",lenc);
    for(i=0;i<lenc;i++) scanf("%1s",&C.at(i));
    cout<<"\nМножество C:";
    C=universal(C);
    print(C);
    vector<char> I;//универсальное множество от a до z
    for(i=97;i<122;i++) I.push_back(i);//224-255 - русские, но хз как с ними работать
    do
    {
        cout<<"\n\nВыберите операцию:";
        cout<<endl<<"1) A+B";
        cout<<endl<<"2) A-B";
        cout<<endl<<"3) A\\B";
        printf("\n4) A%cB",30);
        printf("\n5) neA");
        printf("\n6) B\\C\\A(neC+B-neA)\n");
        int oper;
        scanf("%d",&oper);
        vector<char> d;
        if(oper==1) {d=fusion(A,B);}                                                                        //объединение
        if(oper==2) {d=crossing(A,B);}                                                                      //пересечение
        if(oper==3) {d=margin(A,B);}                                                                        //разность
        if(oper==4) {d=fusion(crossing(A,addition(B,I)),crossing(B,addition(A,I)));}                        //симметрическая разность
        if(oper==5) {d=addition(A,I);}                                                                      //дополнение (отрицание)
        if(oper==6) {d=margin(B,(margin(C,(crossing(A,(fusion(addition(C,I),crossing(B,addition(A,I)))))))));}//задание по варианту
        cout<<"\n\nРезультат:\n";
        print(d);
        printf("\nХотите сделать другую операцию над множествами(y/n)?");
        cin>>ans;
    }
    while((ans=='y')&&(ans!='n'));
    return 0;
}
Добавлено через 1 минуту
sym_margin - другая функция для реализации симметрической разности
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 00:31. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru