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

Как убрать округления - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Решение Системы уравнений http://www.cyberforum.ru/cpp-beginners/thread334364.html
У меня задача - решать систему уравнений. матрица системы имеет порядок 3600. В будущем придется решать системы порядка 100 000. Мне дана матрица коэффициентов. Дана она мне в необычном виде. Исходная СЛУ 4x1 + 2x2 + 9x3 = 1 x2 + 6x3 = 7 4x1 + 2x3 = 0 коэффициенты исходной СЛУ (1;4)(2;2)(3;9) (2;1)(3;6)
C++ string Почему не работает этот кусок проги ? #include "stdafx.h" #include <string.h> void main() { string s; http://www.cyberforum.ru/cpp-beginners/thread334363.html
СИ: одновременный вызов функции. библиотека. C++
Трудно задать вопрос, когда не очень понятно, что нужно получить в ответ. Попробую так: Пусть есть некий my_lib.so/dll содержащий функцию foo(). Поскольку к foo() может произойти "одновременно" несколько обращений, то желательно каким либо образом организовать их обработку (в очередь поставить или ещё что). Собственно вопрос, что именно нужно сделать и в какую сторону смотреть? Как...
Из символов в буквы C++
Знаю один из методов защиты от переполнения массива. char str; cout<<"Введите строчку символов --> "; cin>>setw(40)>>str; } Мне надо проделать такую же защиту с типом данных
C++ Стопариться программа http://www.cyberforum.ru/cpp-beginners/thread334330.html
Задача - решить систему линейных уравнений. Мне дана матрица коэффициентов. Дана она мне в необычном виде. Исходная СЛУ 4x1 + 2x2 + 9x3 = 1 x2 + 6x3 = 7 4x1 + 2x3 = 0 коэффициенты исходной СЛУ (1;4)(2;2)(3;9) (2;1)(3;6) (1;4)(3;2)
C++ Чтение из .txt Матриц #include <iostream> #include <math.h> #include <windows.h> #include <iomanip> #include <fstream> using namespace std; int main() { SetConsoleCP(1251); //Òóïêà, øðèôò íå çàáóäü Lucida подробнее

Показать сообщение отдельно
Stas0n
3 / 4 / 0
Регистрация: 13.07.2011
Сообщений: 313
19.07.2011, 13:27  [ТС]     Как убрать округления
Исходная СЛУ
4x1 + 2x2 + 9x3 = 1
x2 + 6,69x3 = 7
4x1 + 2x3 = 0
коэффициенты исходной СЛУ
(1;4)(2;2)(3;9)
(2;1)(3;6,69)
(1;4)(3;2)
Каждая строка файла содержит информацию о ненулевых коэффициентах одного уравнения СЛУ.
Количество строк в файле соответствует количеству уравнений СЛУ.
Порядковый номер строки в файле соответствует номеру уравнения i.

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

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

Мне её надо привести к квадратному виду. Вот код:
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
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();
 
    // Построение нулевой матрицы
    int const range = 5;
    double matrix[range][range] = {0};
    
    // считывание в одномерный вектор элементов 3.txt
    double b;
    vector <double> stringMatrix;
    ifstream fin2("2.txt");
    ofstream ofs3("3.txt");
    while ( fin2 >> b )
    {
        stringMatrix.push_back(b);
    }
 
    // Итоговая матрица коэфициентов
    int iter = 0;
    int string = 0;
    int column;
    while ( iter < stringMatrix.size() )
    {
        if ( stringMatrix[iter] != 0 )
        {
            column = stringMatrix[iter] - 1;
            matrix[string][column] = stringMatrix[iter+1];
            iter = iter + 2;
        } else 
        {
            if ( iter == stringMatrix.size() )
            {break;}
            else { iter++; 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; }
        }
    }
}
 Комментарий модератора 
Теги форматирования кода.
 
Текущее время: 11:06. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru