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

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

Восстановить пароль Регистрация
 
Elvirohcka
0 / 0 / 0
Регистрация: 03.10.2013
Сообщений: 9
12.11.2013, 13:42     не могу справиться с классами #1
Подскажите, как мне проверить, пуст ли файл? т.е. какую функцию использовать? в программе 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");
}
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
12.11.2013, 13:42     не могу справиться с классами
Посмотрите здесь:

C++ Не могу справиться с задачей на BorlC++
Не могу справиться с одномерным массивом:) C++
C++ Не могу справиться с простой программкой
C++ не могу справиться с программами (они несложные)
Не могу справиться с if! C++
C++ Не могу справиться с двумерным массивом
C++ Не могу справиться с функцией с++ istringstream

Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Ответ Создать тему
Опции темы

Текущее время: 07:07. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru