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

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

Войти
Регистрация
Восстановить пароль
 
Stas0n
3 / 4 / 0
Регистрация: 13.07.2011
Сообщений: 313
#1

Непонятная ошибка - C++

20.07.2011, 13:34. Просмотров 389. Ответов 1
Метки нет (Все метки)

Мне дана матрица коэффициентов системы линейных уравнений в необычном виде:
Исходная СЛУ
4x1 + 2x2 + 9x3 = 1
x2 + 6x3 = 7
4x1 + 2x3 = 0
коэффициенты исходной СЛУ
(1;4)(2;2)(3;9)
(2;1)(3;6)
(1;4)(3;2)
Мне надо из данной матрицы сделать обычную матрицу коэффициентов:
4 2 9
0 1 6
4 0 2
Каждая строка файла содержит информацию о ненулевых коэффициентах одного уравнения СЛУ.
Количество строк в файле соответствует количеству уравнений СЛУ.
Порядковый номер строки в файле соответствует номеру уравнения i.

Каждая строка файла состоит из групп чисел (j ; k(i;j))
• Первое число в группе – это значение номера j коэффициента k(i;j) при неизвестном x(j) в уравнении i
• Второе число в группе – это значение коэффициента k(i;j)

Количество таких групп в строке файла (т.е. количество ненулевых коэффициентов в уравнении) может быть любое – от 1 до n, где n – количество неизвестных в СЛУ.

Но это все го лишь пример. У меня же матрица 3638 порядка.
У меня есть код на с++.
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
int main()
{
    // Удаление ненужных разделителей  "(", ")", ";", ","
    // Добавление последним элементом строки - "0"
    // "0" выступит в качестве разделителя в одномерном векторе stringMatrix
    char a;
    ifstream fin1 ("1.txt");
    ofstream ofs2 ("2.txt");
    while (!fin1.eof())
    {
        a = fin1.get();
        if (fin1.eof()) break;
        if ( a == '(' ){ ofs2 << ""; } else 
        if ( a == ';' || a == ')' ){ ofs2 << " "; } else 
        if ( a == ',' ){ ofs2 << "."; } else
        if ( a == '\n' ){ ofs2 << "0" << "\n";}
        else { ofs2 << a; }
    }
    fin1.close(); 
    ofs2.close();
 
    // Построение нулевой матрицы с помощью кучи
    long int const range = 3;
    double **matrix = new double*[range];
    for (int i = 0; i < range; i++) 
    {
        matrix[i] = new double[range]();
    }
 
    // считывание в одномерный вектор элементов 3.txt
    double b;
    vector <double> stringMatrix;
    ifstream fin2("2.txt");
    ofstream ofs3("3.txt");
    while ( fin2 >> b )
    {
        stringMatrix.push_back(b);
    }
 
    // Итоговая матрица коэфициентов
    long int schetchik = 0;
    long int string = 0;
    long int column;
    while ( schetchik < stringMatrix.size() )
    {
        if ( stringMatrix[schetchik] != 0 )
        {
            column = stringMatrix[schetchik] - 1;
            matrix[string][column] = stringMatrix[schetchik+1];
            schetchik = schetchik + 2;
        } else 
        {
            schetchik++; string++;
            /*if ( schetchik == stringMatrix.size() )
            {break;}
            else { schetchik++; string++; }*/
        }
    }
 
    // Вывод матрицы коэффициентов
    for ( int p = 0; p < range; p++)
    {
        for ( int o = 0; o < range; o++)
        {
            ofs3 << matrix[p][o] << " ";
            if ( o == range-1 ) { ofs3 << endl; }
        }
    }
 
    // Вывод матрицы коэффициентов - способ 2
    /*for ( int i =0; i < range; i++)
    {
        copy ( matrix[i], matrix[i] + range, ostream_iterator< double>( ofs3, " "));
    ofs3.put('\n');
    }
    ofs3.close ();*/
 
    // Освобождение памяти
    for ( int i =0; i < range; i++)
    delete[] matrix[i];
    delete[] matrix;
}
Вот программа. краткое описание текстовых файлов.
1.txt - тестовая версия системы (маленького порядка)
2.txt - результат "убирания" скобок, точек с запятой + добавление в конец каждой строчки по нулю
3.txt - итоговая матрица
4.txt - матрица коэффициентов, для которой и писался код ( порядок - 3638)
Прогу тоже прикрепил
0
Вложения
Тип файла: rar 3 - test.rar (7.38 Мб, 5 просмотров)
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
20.07.2011, 13:34
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Непонятная ошибка (C++):

Непонятная ошибка - C++
Не могу понять, где неправильно. У меня есть такая матрица А 1 4 2 1 3 6 1 5 2 2 3 5 Мне же её надо преобразовать к такому...

Непонятная ошибка - C++
#include &lt;iostream&gt; #include &lt;string&gt; using namespace std; class CMessage { private: char *Text; char...

Непонятная ошибка - C++
Программа должна заменять в строке все пары АВ на С, пишу в Visual Studio, после ввода строки открывается вкладка output.c и показывает...

непонятная ошибка - C++
Здравствуйте. Вот в этой программе у меня пишет ошибку: cpp(60) : error C2065: 'j_max' : undeclared identifier. Хотя если вместо Y...

непонятная ошибка - C++
#include &lt;iostream&gt; using namespace std; void main() { int **a, **b, n; cin &gt;&gt;n; a = new int *; for (int i=0; i&lt; n;...

Непонятная ошибка - C++
Здравствуйте!Начинаю изучать C++,хотел сделать калькулятор логики,арифметический и закона Ома. После расчета в любом калькуляторе,кроме...

1
Stas0n
3 / 4 / 0
Регистрация: 13.07.2011
Сообщений: 313
20.07.2011, 15:45  [ТС] #2
В качестве результата выводит просто нулевую матрицу. В чем дело?
0
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
20.07.2011, 15:45
Привет! Вот еще темы с ответами:

Непонятная ошибка - C++
Всем привет! Вообщем вот функция, которая переводит двоичное число в десятичное, + ещё пару кусков кода, чтобы было понятно, что и откуда...

непонятная ошибка - C++
Начал изучать с++. Все шло хорошо, но потом я столкнулся с проблемой, использовал bass.lib и bass.h. при компиляции выходит такая...

Непонятная ошибка - C++
Добрый день. Переделывал код http://www.cyberforum.ru/cpp-beginners/thread53080.html под свои нужды. Немогу понять в чём ошибка. Заранее...

Непонятная ошибка - C++
Здравствуйте, есть задача с графами - соединенные точки и тп, вот попытался сделать структуры и классы для этой задачи и получил ошибку...


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

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

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