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

Класс "алфавит" - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Дан упорядоченный по неубыванию массив A из N чисел и число X http://www.cyberforum.ru/cpp-beginners/thread744081.html
Дан упорядоченный по неубыванию массив A из N чисел и число X. Получить массив B, вставив X в A так, чтобы B был упорядочен по неубыванию. Зарание Благодарен.
C++ Тест по c++ Вариант 3 1. Есть ли тут ошибка, если да, то какая? class T { int p; public: void f(int a); }; 2.Если тело метода f занимает 20 строк кода, то какая реализация метода лучше? 1 http://www.cyberforum.ru/cpp-beginners/thread744065.html
Перевод целого (дробного) числа из двоичной системы счисления в десятичную C++
Здравствуйте. Написали программу в С++, но считает не все значения. помогите найти ошибку. #include <stdio.h> #include <math.h> #include <iostream> #include <conio.h> using namespace std; int main () {
C++ Упорядовачивание одномерного массива через функцию
Суть задания : разместить все элементы с положительными значениями в левой части массива, элементы с отрицательными значениями в правой части массива, а нули между ними. Обязательные условия : 1)одномерный массив из 100 эл. заполнить рандомно в диапазоне от -100 до +100 2)использовать 3 функции (с этим самая сложность) Добавлено через 4 минуты #include <iostream>
C++ Написать программу поиска двух одинаковых подряд идущих символа в файле http://www.cyberforum.ru/cpp-beginners/thread744020.html
помогите пожалуйста!! напишите программу которая принимает с клавиатуры название файла и выводит на экран "Есть", если в файле присутствуют 2 одинаковых идущих подряд символа и "Нет"-в противном случае.
C++ Переделать программу с классами(Реализовать и исследовать алгоритм Краскала для нахождения стягивающего дерева) Вообщем само задание: Реализовать и исследовать алгоритм Краскала для нахождения стягивающего дерева наименьшей стоимости для неориентированного графа с нагруженными рёбрами. Программа рабочая. Нужно переделать её с классами. Задача не трудная, но у меня есть небольшие сложности с пониманием классов как таковых. Вообщем буду рад любой помощи. #include <stdio.h> #include <conio.h>... подробнее

Показать сообщение отдельно
Dark Alchemist
0 / 0 / 0
Регистрация: 28.05.2011
Сообщений: 7

Класс "алфавит" - C++

24.12.2012, 09:26. Просмотров 280. Ответов 0
Метки (Все метки)

Добрый день! Просьба помочь. Во вложении задание. Сделал все, кроме 3 пункта. Необходимо задать память динамически, создать копирующий конструктор и переопределить экземпляр класса.
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
#include<conio.h>
#include<iostream.h>
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#include<iomanip.h>
 
 
class alphabet {private: int n;char c[100];
     public:alphabet();
        alphabet(int,int);
        alphabet(char*);
    friend istream& operator>>(istream& in,alphabet& p);
    friend ostream& operator<<(ostream& on,alphabet& p);
    alphabet& operator+(alphabet&);
    alphabet& operator+=(char);
    char* cipher(char*,int);
    char* decipher(char*,int);
    int check (char);
    int checkall(char*);
    int over();
    };
 
 alphabet::alphabet(){n=0;c[0]=NULL;}
 
 alphabet::alphabet(int c0,int k){int i;
    n=k;
    for(i=0;i<n;i++)c[i]=c0+i;c[n]=0;}
 
 alphabet::alphabet(char* s){int i;n=strlen(s);
    strcpy(c,s);}
 
 int alphabet::over(){int i,j;for(i=0;i<n-1;i++)
    for(j=i+1;j<n;j++)
    if(c[i]==c[j])
    return 0;
    return 1;}
 
 istream& operator>>(istream& in,alphabet& s){int i;
       cout<<"Enter String=";in.getline(s.c,80);
       s.n=strlen(s.c);
       return in;}
 
ostream& operator<<(ostream& on,alphabet& s){int i;
    on<<"You See Current Alphabet of "<<s.n<<" characters : "<<endl;
    on<<s.c;return on;}
 
alphabet& alphabet:: operator+(alphabet& b){
strcat(c,b.c);n=n+b.n;
    return *this;}
 
alphabet& alphabet::operator+=(char s){
    if(check(s)){cout<<"Symbol Alredy Exists,";return *this;}
    c[n]=s;c[n+1]=0;n++;
    return *this;}
 
 
int alphabet::check(char t){int i; for(i=0;i<n;i++)
    if(t==c[i])return 1;return 0;}
 
int alphabet::checkall(char*t){int i,j;
    for(j=0;j<strlen(t);j++){
    for(i=0;i<n;i++)
    if(!check(t[j]))return 0;}
    return 1;}
 
char* alphabet::cipher(char*s,int t){int i;
    for(i=0;i<strlen(s);i++)
    s[i]=s[i]+t;
    return s;};
 
char* alphabet::decipher(char*s,int t){
    int i;for(i=0;i<strlen(s);i++)
    s[i]=s[i]-t;return s;};
 
void main(){alphabet my;int key,c0,k;char tst[100];char t;
    textmode(C80);
    do{ textattr(0x1F);
    clrscr();
    cprintf("1-Make1,2-Make2,3-Make3,4-Enter,5-Show,6-Sum,Esc-Quit\n\r");
    cprintf("7-Add,8-Cipher,9-Decipher\n\r");
    switch(getch()){
case'1':cout<<my;break;
case'2':cout<<"C0=";cin>>c0;cout<<"K=";cin>>k;
    alphabet my(c0,k);cout<<my;break;
case'3':cout<<"Enter String=";cin>>tst;cin.ignore();
    alphabet b(tst);cout<<b;
    if(!(b.over()))
    cout<<"\nAlphabet Not Correct!";break;
case'4':cin>>my;
    cout<<my;
    if(!(my.over()))
    cout<<"\nAlphabet Not Correct!";break;
case'5':cout<<my;break;
case'6':cout<<"Enter Alphabet N2,";cin>>b;cout<<(my=my+b);
    if(!(my.over()))
    cout<<"\nAlphabet Not Correct!";break;
case'7':cout<<"Enter Character=";cin>>t;cout<<(my+=t);
    break;
case'8':cout<<"Enter String=";cin>>tst;cout<<"Enter Key=";cin>>key;
    if (my.checkall(tst))cout<<my.cipher(tst,key);
    else {cout<<"String Incorrect!";break;}
    if (!(my.checkall(tst)) )
    cout<<"\nString Is Not In Alphabet";
    break;
case'9':cout<<"Enter Key=";cin>>key;cout<<my.decipher(tst,key);break;
case 27:exit(0);
 }
getch();}
while(1);
}
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru