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

Реализовать класс "наследник" - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Ошибка LNK 2019 - C++ (Visual Studio 2011) http://www.cyberforum.ru/cpp-beginners/thread1776456.html
Доброго времени суток. Помогите пожалуйста разобраться. Не удается запустить проект из 3-х файлов. Проект создавался "пустой". Если весь код написать в одном файле - работает, а если в разных - нет. Текст файла MyMain.cpp (с функций main) ______________________________________ #include <iostream> #include <time.h> #include <conio.h> #include "MyLIFO-3.h" using namespace std; void main...
C++ Извлечение данных из файла Не могу придумать способ извлечения данных из файла с форматированием (проблема с функцией diskIn(pn)). Нужно чтобы функция умела извлекать определенную запись. #include<iostream> #include<fstream> #include<process.h> using namespace std; const int sz=20; class cname { private: char name; char sname; http://www.cyberforum.ru/cpp-beginners/thread1776435.html
Сдвиг столбцов матрицы C++
Добрый вечер. Может кто помочь со следующей задачей? Заполнить двумерный массив случайными числами и показать на экран. Сдвинуть все столбцы массива на X позиций (число X вводит пользователь) влево. Например, если Х=2, то массив: 1 2 3 4 5 5 6 7 8 9 6 7 8 9 0 примет следующий вид: 3 4 5 1 2 7 8 9 5 6 8 9 0 6 7
Не открывается файл для чтения C++
Не могу разобраться с кодом , не получается прописать входной фаил , не принимает его .. #include <stdio.h> #include <math.h> #define MAX 100 double x, y; int n;
C++ Не работают команды system() http://www.cyberforum.ru/cpp-beginners/thread1776359.html
#include<cstdlib> #include<iostream> #include<windows.h> int main(int a, char* b) { ... system("cls"); system("pause"); ... return 0;}
C++ Записать каждые 16 символов из файла в вектор Как прочитать txt файл и записать каждые 16 символов в вектор? Я сделал вот так: std::vector<char> text_v; char time_text; std::ifstream in; in.open("123.txt"); while (in.eof() == false){ in.get(time_text, 16); text_v.push_back(time_text); подробнее

Показать сообщение отдельно
hostel656
0 / 0 / 0
Регистрация: 18.03.2016
Сообщений: 82

Реализовать класс "наследник" - C++

06.07.2016, 10:42. Просмотров 189. Ответов 2
Метки (Все метки)

Spisok.h
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
#pragma once
class Spisok
{
    int size1;
    int size2;
    int **mas;
    
public:
    Spisok(int,int);
    ~Spisok();
    int get(int, int); // выводим значений отдельных элементов
    void get(); // выводим матрицу
    void sort1(int); //сортировка по номеру строки
    void sort2(int); //сортировка по номеру столбца
};
Spisok.cpp
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
#include "stdafx.h"
#include "Spisok.h"
#include <stdio.h>
#include <stdlib.h>
#include <time.h>
#include<iostream>
#include<conio.h>
 
Spisok::Spisok(int n, int m)
{
    size1 = n;
    size2 = m;
    mas = new int*[size1];
    for (int i = 0; i < size1; i++)
        mas[i] = new int[size2];
    srand(time(NULL));
    for (int i = 0; i < size1; i++)
        for (int j = 0; j < size2; j++)
            mas[i][j] = rand() % 100;
} //инициализация поля и заполнение его рандомными числами
Spisok::~Spisok()
{
}
int Spisok::get(int n, int m)
{
    return mas[n - 1][m - 1];
}//вывод определённой ячейки
void Spisok::get()
{
    for (int i = 0; i < size1; i++)
    {
        std::cout << "\n";
        for (int j = 0; j < size2; j++)
            std::cout << mas[i][j] << "\t";
    }
}//вывод матрицы
void Spisok::sort1(int n)
{
    for (int i = 0; i < size2 - 1; i++)
    {
        if (mas[n][i] > mas[n][i + 1])
        {
            int z;
            z = mas[n][i];
            mas[n][i] = mas[n][i + 1];
            mas[n][i + 1] = z;
            i = -1;
        }
    }
}//сортировка по номеру строки
void Spisok::sort2(int n)
{
    for (int i = 0; i < size1 - 1; i++)
    {
        if (mas[i][n] > mas[i + 1][n])
        {
            int z;
            z = mas[i][n];
            mas[i][n] = mas[i + 1][n];
            mas[i + 1][n] = z;
            i = -1;
        }
    }
}//сортировка по номеру столбца
Главный файл
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
// Виселица.cpp: определяет точку входа для консольного приложения. 
// 
#include "stdafx.h"
#include "Spisok.h" 
#include <iostream> 
#include <stdio.h> 
#include <locale.h> 
#include <windows.h> 
using namespace std;
 
int main()
{
    setlocale(LC_ALL, "Russian");
    int i = 1, n = 1, m = 1;
    Spisok *T = nullptr;
    while (i != 0)
    {
        cout << endl << "Напишите, что вы хотите сделать";
        cout << endl << "1)Cоздать матрицу";
        cout << endl << "2)Получить число по положению";
        cout << endl << "3)Получить матрицу";
        cout << endl << "4)Отсортировать по строке";
        cout << endl << "5)Отсортировать по столбцу";
        cout << endl << "6)Завершить программу" << endl;
        int b;
        cin >> b;
        switch (b)
        {
        case 1:
        {
            cout << endl << "Введите размеры списка\n";
            int n, m;
            cin >> n >> m;
            T = new Spisok(n, m);
            break;
        }
        case 2:
        {
            if (T == nullptr)
                std::cout << "Не заданы размеры матрицы!!!\n";
            else
            {
                cout << endl << "Введите положение\n";
                int n, m;
                cin >> n >> m;
                cout << "\nЧисло в этом положении =" << T->get(n, m);
            }
            break;
        }
        case 3:
        {
            if (T == nullptr)
                std::cout << "Не заданы размеры матрицы!!!\n";
            else
                T->get();
            break;
        }
        case 4:
        {
            if (T == nullptr)
                std::cout << "Не заданы размеры матрицы!!!\n";
            else
            {
                cout << endl << "Введите номер строки \n";
                int z;
                cin >> z;
                T->sort1(z - 1);
            }
            break;
        }
        case 5:
        {
            if (T == nullptr)
                std::cout << "Не заданы размеры матрицы!!!\n";
            else
            {
                cout << endl << "Введите номер столбца\n";
                int z;
                cin >> z;
                T->sort2(z - 1);
            }
            break;
        }
        case 6:
        {
            i = 0; break;
        }
        default:
        {
            cout << "Такой ф-ции нет, попробуйте снова";
            break;
        }
        }
    }
    return 0;
}
Помогите реализовать класс наследник содержащий дополнительные методы вычисления скалярного произведения двух заданных строк и/или двух заданных столбцов.
Заранее огромное спасибо!!!
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru