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

Не могу найти ошибку - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ указатели http://www.cyberforum.ru/cpp-beginners/thread1106076.html
Вот собственно код, проблема в том что я непойму как он работает, что именно непонятно указал в комментариях unsigned char ** tipoTerreno, **estaticos;//создается что, массив указателей? unsigned short ** elevacion; for (int m = 0; m < d1; m++) { tipoTerreno = new unsigned char ;//а это что такое? создание двумерного массива? elevacion = new unsigned short ; ...
C++ Увидеть обработанный препроцессором код Как увидеть обработанный препроцессором код? (например, хочу своими глазами увидеть как слово inline в определении методов влияет на окончательную версию кода) PS: у меня Visual Studio 2013 Express http://www.cyberforum.ru/cpp-beginners/thread1106074.html
Дано натуральное число N C++
Дано натуральное число N. Вычислить : Здравствуйте,интересует эта задача, может кто-то написать решение и посоветовать что-либо из литературы по этому случаю? Добавлено через 13 минут \sum_{i=1}^{N} {a}_{i}^2 {a}_{i}=\left\{\begin{matrix} i/3 \\ i/(i-3) \end{matrix}\right. первая строка при i, кратном 3;
Заполнить матрицу по правилу C++
Матрицу A (m, n) заполнить следующим образом. Для заданных k и l элемента akl присвоить значение 1; элементам, окружающих его - значение 2; элементам следующий круг окружения - значение 3 и т.д. до заполнения всей матрицы
C++ Каждый элемент массива заменить минимальным http://www.cyberforum.ru/cpp-beginners/thread1106049.html
Кожен елемент ti масиву T (m) замінити мінімальним серед перших i елементів цього масиву
C++ Как упростить код Все работает, все компилируется... Можно как нибудь упростить код, сделать его более грамотным с точки зрения асов...? #include"stdafx.h" #include<conio.h> #include<fstream> #include<iostream> using namespace std; int main() подробнее

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

Не могу найти ошибку - C++

26.02.2014, 17:46. Просмотров 153. Ответов 2
Метки (Все метки)

Добрый день! Третий день маюсь. Программа решает систему уравнений методом Гаусса. Программа разделена на две функции: в первой функции вводятся коэффициенты и свободные члены системы, и сразу же сохраняются в файл; во второй функции программа читает матрицу из файла в массив, выполняет рассчет и сохраняет результат в отдельный файл.
Суть проблемы: когда выполняются первая и вторая функция друг за другом, без закрытия консоли, то всё работает отлично. Но если выполнить только первую функцию, перезапустить консоль и выполнить вторую, программа не совершает расчёт. Сначала думал, что считывание из файла в массив не работает, но потом я убедился в обратном. Может у кого-то есть какие-нибудь идеи?
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
// laba1.cpp: определяет точку входа для консольного приложения.
//
 
#include "stdafx.h"
#include <iostream>
#include <iomanip>
#include <stdio.h>
#pragma warning(disable: 4996)
using namespace std;
void vvodsohr(); void chtreshsohr();
int n,i, j;
 
FILE *ish;
 
int main()
{
    while (true){
        cout << "MENU:" << endl << "1. Zapis' matricy v file." << endl << "2. Reshenie matricy." << endl << "0. Vyhod." << endl;
        cin >> i;
        switch (i){
        case 1: vvodsohr(); break;
        case 2: chtreshsohr(); break;
        case 0: return 0;
        }
    }
}
 
void vvodsohr(){
 
    ish = fopen("ishodnye_dannye.txt", "wb");
    cout << "Vvedite razmer matricy (nxn): ";
    cin >> n;
    float **a = new float*[n], *b = new float[n]; //инициализация динамических массивов
    for (i = 0; i < n; i++) a[i] = new float[n];
    for (i = 0; i<n; i++){//заполнение массива и запись в файл
        cout << "Vvodite elementy i svobodny chlen stroki " << i + 1 << ":";
        for (j = 0; j < n; j++){ 
            cin >> a[i][j]; 
            fwrite(&a[i][j], sizeof(a[i][j]), 1, ish);
        }
                cin >> b[i];
                fwrite(&b[i], sizeof(b[i]), 1, ish);
    }
    cout <<endl<<"File sozdan, vvodimye dannye sohraneny."<<endl<<endl;
    fclose(ish);
    for (i = 0; i < n; i++) delete[]a[i];
    delete[]a;
    delete[]b;
}
 
void chtreshsohr(){
    ish = fopen("ishodnye_dannye.txt", "rb");
    float **a = new float*[n], *b = new float[n];
    for (i = 0; i < n; i++) a[i] = new float[n];
 
    for (i = 0; i < n; i++){//считывание из файла в массив.
        for (j = 0; j < n; j++)
            fread(&a[i][j], sizeof(float), 1, ish);
        fread(&b[i], sizeof(float), 1, ish);
    }
    
        int f; float k; //приводим к стандартному виду
        for (i = 0; i < n; i++)
        for (f = i + 1; f < n; f++){
            k = a[f][i] / a[i][i];
            b[f] = b[f] - k*b[i];
            for (j = 0; j < n; j++)
                a[f][j] = a[f][j] - k*a[i][j];
        }
        cout << "Standartnaya:" << endl;
        for (i = 0; i < n; i++){//вывод приведенной матрицы
            for (j = 0; j < n; j++)cout << setw(9) << a[i][j] << " ";
            cout << "|" << b[i] << endl;
        }
 
        float s = 0, *x = new float[n];//находим x
        for (i = 0; i<n; i++) x[i] = 0;
        for (i = n - 1; i >= 0; i--){
            s = b[i];
            for (j = n - 1; j>i; j--) s -= x[j] * a[i][j];
            x[i] = s / a[i][i];
        }
 
        for (i = 0; i < n; i++) cout <<"x"<<i+1<<"="<< x[i] << " ";
        cout << endl<<endl;
        fclose(ish);
        FILE *rez = fopen("rezult.txt", "wb");//запись иксов в файл
        for (i = 0; i < n; i++)
            fwrite(&x[i], sizeof(x), 1, rez);
        fclose(rez);
        for (i = 0; i < n; i++) delete[]a[i];
        delete[]a;
        delete[]b;
        delete[]x;
    }
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru