Форум программистов, компьютерный форум, киберфорум
Наши страницы

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
Elvirohcka
0 / 0 / 0
Регистрация: 03.10.2013
Сообщений: 9
#1

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

12.11.2013, 13:42. Просмотров 204. Ответов 0
Метки нет (Все метки)

Подскажите, как мне проверить, пуст ли файл? т.е. какую функцию использовать? в программе 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");
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
12.11.2013, 13:42
Я подобрал для вас темы с готовыми решениями и ответами на вопрос не могу справиться с классами (C++):

Не могу справиться с if! - C++
Вот код: #include &lt;iostream.h&gt; #include &lt;stdio.h&gt; int main() { using namespace std; string name; cout &lt;&lt; &quot;Type name: ...

Не могу справиться с функцией с++ istringstream - C++
В общем, изначальный код был таков: #include &quot;stdafx.h&quot; #include&lt;iostream&gt; #include &lt;conio.h&gt; #include &lt;sstream&gt; #include...

Не могу справиться с задачей на BorlC++ - C++
Дерево Пифагора – такая вещь, когда все начинается с квадрата, который на одной из сторон имеет равнобедренный прямоугольный треугольник....

не могу справиться с программами (они несложные) - C++
Парни, от меня в универе требуют к четвергу написать проги на C++, я написала около 9, осталось только 3.. помогите пожалуйста :-[ ...

не могу справиться задачкой в С++. У кого светлая голова напишите пожалуйста - C++
Задан массив, состоящий из 10 элементов. Из положительных элементов извлечь квадратный корень, отрицательные возвести в квадрат, нулевые...

Не могу разобраться с классами - C++
InitD3DWindow.h ------------------- class InitD3DWindow { protected: //Initialize the app Window bool InitWindow();

0
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
12.11.2013, 13:42
Привет! Вот еще темы с ответами:

Не могу разобраться с функциями и классами - C++
Уважаемые гуру! Подскажите, пожалуйста, мне такой вопрос. Пишу небольшое консольное приложение-игру. Есть у меня класс Character, с...

Не могу разобраться с классами и освобождением памяти - C++
Есть задача. Создать класс матрица Данный класс содержит указатель на float, размер строк и столбцов и состояние ошибки. Определить...

Не могу справиться с задачей: "по какому предмету у студента с заданным номером в журнале лучшая оценка по итогам сессии?"! - C++
Задача выглядит так: &quot;по какому предмету у студента с заданным номером в журнале лучшая оценка по итогам сессии?&quot; То есть дан список...

Помогите справиться с задачей!! - C++
Начал изучать С++ и попалась задача, не подскажите как ее сделать? Задача 2.29 Для действительных чисел х и а составить функцию...


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

Или воспользуйтесь поиском по форуму:
1
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2018, vBulletin Solutions, Inc.
Рейтинг@Mail.ru