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

Помогите разобраться в Наследование - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ разработать класс http://www.cyberforum.ru/cpp-beginners/thread354933.html
Здравствуйте, задание такое: Разработать класс, представляющий студента. Студент характеризуется именем, фамилией, группой и набором экзаменов, которые он сдавал. Экзамен характеризуется названием предмета, оценкой студента по нему и датой сдачи (год, семестр). Группа характеризуется курсом и факультетом. Необходимые операции таковы: 1. узнать полное имя студента (имя+фамилия) и его курс 2....
C++ Нужны готовые процедуры для работы с матрицами Господа форумчане не у кого из вас нет готовых процедур для работы с матрицами(умножение обращение и тд)? http://www.cyberforum.ru/cpp-beginners/thread354917.html
создать класс C++
создать класс типа "циклическая последовательность".Функции-члены получают элемент и помещают его в последовательность.Предусмотреть функцию вывода последовательности на экран.для хранения использовать динамический массив. помогите пожалуйста..
C++ выводит на экран изображение кораблика.
#include <windows.h> #include <cstring> #include <cstdio> using namespace std; #define Blue RGB (0,0,255) int drawLine (HWND,int,int,int,int,int,HDC=0); int main() {
C++ Вывести слова без повторений,которые имеют больше гласных,чем согласных. http://www.cyberforum.ru/cpp-beginners/thread354868.html
Пусть у нас есть текстовый файл,на который не накладываются ограничения относительно его размера. Также не накладываются ограничения на длину строки в этом файле. Текст состоит из слов,например,идентификаторы английского языка. Слова разделяются промежутками, скобками,кодами операций,вообще символами,которые естественным образом отделяют слова друг от друга. Пусть ограничение на длину слова...
C++ задачки на С++. циклы и двумерные массивы Помогите решить задачки по C++ к зачету. очень нужно 1. Цикл For... Среди всех n-значных чисел (n = 1,2,3,4) указать те, сумма цифр которых равна данному числу k. 2. двумерные массивы Дана целочисленная квадратная матрица. Найти в каждой строке наиболь¬ший элемент и поменять его местами с элементом главной диагонали. Дана действительная квадратная матрица порядка 2N. Подучить новую матрицу,... подробнее

Показать сообщение отдельно
Ree.exe
56 / 56 / 4
Регистрация: 01.08.2011
Сообщений: 141
22.09.2011, 16:31     Помогите разобраться в Наследование
Вот немного переделал твой код.
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
#include<iostream>
#include<cstring>
using namespace std;
class String1
{
protected:
        enum {SZ=80};
        char str[SZ];
public:
        String1(const char* s="")
        {
            if(strlen(s)>79)
            {
                for(int i=0; i<79 ; i++)
                    str[i]=s[i];
                str[80-1]='\0';
            }
            else
                strcpy(str,s);
        }
        void display()const
        {
            cout<<str;
        }
};
/*  Зачем этот класс?
class String2:public String1
{
public:
        String2(const char* s="")
        {
                if(strlen(s)<SZ-1)
                        String1(s);
                if(strlen(s)>SZ-1)
                {
                        for(int j=0;j<SZ-1;j++)
                                str[j]=s[j];
                        str[SZ-1]='\0';
                }
        }
};
*/
class String3:public String1
{
public:
        
        String3(const char* s=""): String1(s)
        {
                
        }
        char& left(char s[],int n)//Добавление n символов в строку с лева
        {
                for(int i=0;i<n;i++)
                        str[i]=s[i];
                str[n]='\0';
                return *str;
        }
        char& mid(char s[],int S,int n)//Добавление n символов в строку с символа S
        {
                for(int i=0,z=S;i<n;i++,z++)
                        str[i]=s[z];
                str[n]='\0';
                return *str;
        }
        char& right(char s[],int n)//Добавление n символов в строку с права
        {
                for(int i=0,z=strlen(s)-n+1;i<n;i++,z++)
                        str[i]=s[z];
                str[n]='\0';
                return *str;
        }
};
int main()
{
    setlocale(LC_ALL,"");
        String3 s1("This is a very long string which is probably no, certainly--going to exceed the limit set by SZ.");
        cout<<"\ns1=";
        s1.display();
        String3 s2="This is a short string.";
        cout<<"\ns2=";
        s2.display();
        cout<<endl;
        return 0;
}
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru