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

не могу справиться с классами - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Можно ли перевести заглавную букву в маленькую не используя для этого функций? http://www.cyberforum.ru/cpp-beginners/thread1005396.html
Я знаю что нужно вроде бы отнять 32, но как это правильно сделать с типом string?
C++ Найти произведение элементов массива, расположенных после минимального элемента Написать и отладить программу создания одномерного массива из 30 случайных целочисленных элементов, которые принадлежат интервалу . Найти произведение элементов массива, расположенных после минимального элемента. Помогите сделать последнее задание. Нужно продолжить программу. //lab1 #include <iostream.h> #include <stdlib.h> void main (void) {randomize(); int pr,i,f; float M,min; min=31; http://www.cyberforum.ru/cpp-beginners/thread1005389.html
Dev C++ (Не является приложением win32) C++
Добрый день. Использую Dev C++. При попытке повторить любой пример оконного приложения, компилирует без ошибок, но при попытке запуска .exe через F10 "не является приложением win32". Напрямую файл запускается отлично.
C++ Строки, подсчёт букв
Задание посчитать кол-во букв i в строке. #include <iostream.h> #include <string.h> main() { int x; char s; cout<<"Vvedite stroku: "; cin>>s; for(int y=0; y<strlen(s); y++)
C++ что-то с передачей данных http://www.cyberforum.ru/cpp-beginners/thread1005356.html
Тема: Наследование (множественное, виртуальное). 4. Создайте программу: с базовым классом Справочник, который включает в себя следующие данные-элементы: • Наименование продукции; • Код продукции; методы – конструкторы, деструктор, show() базовым классом Остатки на начало месяца: • Остатки на начало месяца;
C++ Ошибку в коде C++ Всем привет! Выдаёт ошибку в коде: double max = dlina(t, t); не знаю что делать... Заданы координаты N точек на плоскости. Найти среди них две точки, максимально удаленные друг от друга. #include "fstream" #include <cmath> using namespace std; подробнее

Показать сообщение отдельно
Elvirohcka
0 / 0 / 0
Регистрация: 03.10.2013
Сообщений: 9
12.11.2013, 13:42     не могу справиться с классами
Подскажите, как мне проверить, пуст ли файл? т.е. какую функцию использовать? в программе 2 класса наследника, которые создают узлы интерполяции для полинома лагранжа... возникли проблемы с формированием этого полинома. Помогите, прошу вас!!!

Классы:
//polinom.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
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
#include "Polynom.h"
#include<iostream>
#include<fstream>
using namespace std;
 
Polynom::Polynom(void){
    n = 0;
    a = new float [n+1];
    for(int i=1; i<=n; i++)
        a[i]=0;
} 
 
Polynom::Polynom(int N){
    if (N>=0){
    n = N;
    a = new float [n+1];
    for(int i=1; i<=n; i++)
        a[i]=0;
    }
}
 
int ReadFileB(const char* fileName){
    ifstream f1;
    f1.open(fileName,ios_base::in);
    if (f1&&f1.is_open()){
            if(!f1){
            return 0;
        }
            while(!f1.eof()){
        return 1;
    } 
        cout << "Ошибка\n";
        return 0;
    }
}
 
Polynom ReadFile(const char* fileName){
    ifstream f1;
    f1.open(fileName,ios_base::in);
    if (f1&&f1.is_open()){
        int n;
        f1 >> n;
        Polynom t(n);
        int i = -1;
        float k;
        while (!f1.eof()){
            i++;
            f1 >> k;
            t.a[i] = k;
            k = 0;
        }
        return t;
        f1.close();
        }
}
 
ostream& operator <<(ostream& out, Polynom t){
    if (t.n>=0){
        out << "Степень полученного полинома " << t.n << "\n";
        for(int i = 0; i<t.n; i++){
            out << t.a[i] << "x^" << i << " + ";
        }
        out << t.a[t.n] << "x^" << t.n;
        out << " = 0\n" <<"\n";
    }
    return out;
}
 
Polynom::~Polynom(void){
}
 
Polynom Polynom::operator+(Polynom t){
    if(n>=t.n){
        Polynom c(n);
        int i;
        for(i = 0; i<=t.n; i++){
            c.a[i] = a[i] + t.a[i];
        }
        for(i = t.n + 1; i<=n; i++){
            c.a[i] = a[i];
        }
        return c;
    } else {
        Polynom c(t.n);
        int i;
        for(i = 0; i<=n; i++){
            c.a[i] = a[i] + t.a[i];
        }
        for(i = n+1; i<=t.n; i++){
            c.a[i] = t.a[i];
        }
        return c;
    }
}
 
Polynom Polynom::operator-(Polynom t){
    if(n>=t.n){
        Polynom c(n);
        int i;
        for(i = 0; i<=t.n; i++){
            c.a[i] = a[i] - t.a[i];
        }
        for(i = t.n + 1; i<=n; i++){
            c.a[i] = a[i];
        }
        return c;
    } else {
        Polynom c(t.n);
        int i;
        for(i = 0; i<=n; i++){
            c.a[i] = a[i] - t.a[i];
        }
        for(i = n+1; i<=t.n; i++){
            c.a[i] = t.a[i];
        }
        return c;
    }
}
 
Polynom Polynom::operator*(Polynom t){
    if(t.n==0){
        Polynom c(n);
        for(int i = 0; i<=n; i++){
            c.a[i] = t.a[0]*a[i];
        }
        return c;
    } else {
        int k = n + t.n;
        Polynom c(k);
        for (int i = 0; i<=n; i++){
            for (int j = 0; j<=t.n; j++){   
                int k = i+j;
                if(k == 0){
                    c.a[0] = a[0]*t.a[0];
                } else {
                    c.a[i+j] += a[i]*t.a[j];
                }
            }
        }
        return c;
    }
}
 
Polynom Polynom::operator/(Polynom t){
    if(t.n==0){
        Polynom c(n);
        for(int i = 0; i<=n; i++){
            c.a[i] = a[i]/t.a[0];
        }
        return c;
    } else {
        if (n>=t.n){
            int k = n-t.n;
            Polynom c(k);
            for (int i = k; i>=t.n; i = k-t.n){
                c.a[i] = a[n]/t.a[t.n];
                Polynom h = c*t;
                Polynom r = ReadFile("data1.txt");
                Polynom f = r - h;
            }
            return c;
        }
    }
}
//polinom.h
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
#pragma once
#include<iostream>
using namespace std;
 
class Polynom{
protected:
    float *a;
    int n;
public:
    Polynom(void);
    Polynom(int N);
    ~Polynom(void);
    friend Polynom ReadFile(const char* fileName);
    friend int ReadFileB(const char* fileName);
    friend ostream& operator <<(ostream& out, Polynom t);
    Polynom Polynom::operator+(Polynom t);
    Polynom Polynom::operator-(Polynom t);
    Polynom Polynom::operator*(Polynom t);
    Polynom Polynom::operator/(Polynom t);
};
//Uzly.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
#include "Uzly.h"
#include"RavnootstUzly.h"
 
 
Uzly::Uzly(int cnt)
{
    left=-1;
    right=1;
    count=(cnt>2)?cnt:2;
 
}
Uzly::Uzly(int cnt, float left,float right){
    count =(cnt>2)?cnt:2;
    if(left<right){
        this->left=left;
        this->right=right;
    }else{
        this->left=right;
        this->right=left;
    }
    if(left==right){
        right--;
    }
}
 
    RavnootstUzly*ru=new RavnootstUzly(n,-2,(float)3.5);
    float* arr;
    for(int i=0;i<count;i++){
        for(int j=0;j<count;j++){
            if(i!=j){
                arr[i]=ru->GetUzel(i);
                arr[j]=ru->GetUzel(j);
                cout<<arr[i]+arr[j];
                return arr[i]+arr[j];
            }
        }
    }
}
//Uzly.h
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
#pragma once
#include"Polynom.h"
using namespace std;
class Uzly :
public Polynom
{
protected:
    float left,right;
    int count;
 
public:
    Uzly(int cnt);
    Uzly (int cnt,float left,float right);
    float Lag();
};
//RavnootstUzly.cpp
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
#include "RavnootstUzly.h"
 
 
RavnootstUzly::RavnootstUzly(int cnt):Uzly(cnt)
{
}
RavnootstUzly::RavnootstUzly (int cnt,float left,float right):Uzly(cnt,left,right)
{
}
float RavnootstUzly::GetUzel(int i)
{
    float x=left+i*(right-left)/(count-1);
    return x;
}
//RavnootstUzly.h
C++
1
2
3
4
5
6
7
8
9
10
#pragma once
#include "uzly.h"
class RavnootstUzly :
public Uzly
{
public:
    RavnootstUzly(int cnt);
    RavnootstUzly (int cnt,float left,float right);
    float GetUzel(int i);
};
Работа с классами
//main.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
#include"Polynom.h"
#include "RavnootstUzly.h"
#include<iostream>
using namespace std;
 
void main(){
    setlocale(LC_ALL,".1251");
    Polynom t = ReadFile("data1.txt");
    if(ReadFileB("sum.txt")!=0){
    Polynom t1 = ReadFile("sum.txt");
    Polynom t2 = t + t1;
    cout << "Сумма полиномов: \n" << t2;
    }
    Polynom t3 = ReadFile("minus.txt");
    Polynom t4 = t - t3;
    cout << "Разность полиномов: \n" << t4;
    Polynom t5 = ReadFile("multipl.txt");
    Polynom t6 = t * t5;
    cout << "Умножение полиномов: \n" << t6;
    Polynom t7 = ReadFile("divide.txt");
    Polynom t8 = t / t7;
    cout << "Деление полиномов: \n" << t8;
    system("pause");
}
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 03:54. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru