Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск  
 
 
Рейтинг 4.82/11: Рейтинг темы: голосов - 11, средняя оценка - 4.82
3 / 4 / 1
Регистрация: 13.07.2011
Сообщений: 313

Нужно ускорить код

16.09.2011, 19:08. Показов 2498. Ответов 20
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Мне нужно написать программу, для преобразования коэффициентов системы и столбца свободных членов к виду, необходимому для импорта в матпакет.


Приведу наглядный пример на системе из 2-х уравнений:
х_1 + 345,45х_2 = 6,3
х_2 = 4
Матрица коэффициентов в этом случае выглядит вот так:
(1;1)(2;345,45)
(2;1)
Столбец свободных членов выглядит вот так:
6,3
4

В ней только ненулевые коэффициенты.
тут первое число в скобке - это номер коэффициента, второе число в скобке - значение коэффициента, стоящего перед соответствующие переменные. Номер строчки - номер уравнения.

Мне же надо разбить эту матрицы на 2 текстовых файла - в одном - координаты неотрицательных элементов, в другом - значения коэффициентов перед соответствующими переменными. Попутно нужно заменять запятые - точками. А в 3-ий просто переписать столбец свободных членов, но уже заменив все запятые на точки

Вот что должно получиться к приведенному выше примеру:
а-1 - координаты коэффициента
1 1
1 2
2 1

а-2 - значения соответствующих коэффициентов:
1
345.45
1

Столбец свободных членов:
6.3
4

Вот сам код:
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
#include <iostream>
#include <fstream>
#include <sstream>
#include <vector>
#include <string>
#include <iterator>
#include <iomanip>
 
using namespace std;
 
int main()
{
    //-------------------------------------------------------------
    // Приведение столбца свободных членов к виду, необходимому для
    // импорта в SCILab
    // b.txt - исходный столбец
    // bb.txt - искомый столбец
    //-------------------------------------------------------------
    ifstream ifsb ("b.txt");
    ofstream ofsb ("bb.txt");
    char q;
    while( !ifsb.eof() )
    {
        q = ifsb.get();
        if ( ifsb.eof() ) break;
        if ( q == ',' ) { ofsb << "."; }
        else { ofsb << q; }
    }
    ifsb.close();
    ofsb.close();
    //------------------------------------------------------------
    // Приведение матрицу коэффициентов к виду, необходимому для 
    // импорта в матпакет.
    // a.txt - исходная матрица коэффициентов
    // a-1.txt - содержит координаты ненулевых членов
    // а-2.txt - соджержит соотвествующие коэффициенты
    //------------------------------------------------------------
    
    ifstream ifsa ("a.txt");
    ofstream ofsa_1 ("a-1.txt");
    ofstream ofsa_2 ("a-2.txt");
 
    char w;
    int stroka = 1;
    int k = 0;
    ofstream* ptr = &ofsa_1;
    std::string t = "1234567890";
    while ( !ifsa.eof() )
    {
        w = ifsa.get();
        if ( ifsa.eof() ) break;
        if ( w == '(' ) { ptr = &ofsa_1; *ptr << stroka << " "; continue; }
        if ( w == ')' ) { ofsa_2 << endl; }
        if ( w == ',' ) { ofsa_2 << "."; } 
        if ( w == '\n' ) { stroka++; }
        if ( w == ';' ) { *ptr << endl; ptr = &ofsa_2; }
        if ( t.find(w) != t.npos ) 
        { 
            *ptr << w; 
        }
    }
 
}
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
16.09.2011, 19:08
Ответы с готовыми решениями:

Нужно ускорить код. Буду очень благодарен
Условие задачи: Вводиться число n, затем вводятся n чисел. Нужно с последней введенной цифры до первой вывести число, и сколько раз оно...

Как ускорить код?
Есть код : #include &lt;cstdio&gt; #include &lt;cstring&gt; #include &lt;memory.h&gt; #include &lt;iostream&gt; using namespace std; const int N =...

Деление больших чисел (нужно ускорить)
Ребятки, помогите ускорить. Уж очень медленно. Класс совсем простой(вектор со знаком): static const unsigned long long BASE =...

20
3 / 4 / 1
Регистрация: 13.07.2011
Сообщений: 313
22.09.2011, 19:10  [ТС]
Студворк — интернет-сервис помощи студентам
что то как то совсем не очень... код отработал, а а-1 и а-2 - пустые...

Добавлено через 49 минут
и со столбцом b он не работает((
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
22.09.2011, 19:10

Гипотеза Коллатца(ускорить код)
Существует вот такая вот гипотеза Коллатца(https://ru.wikipedia.org/wiki/Гипотеза_Коллатца), которую я отобразил в следующей функции: int...

Код работает долго, нужно ускорить
Программа считает, сколько в среднем времени занимает процедура. На 1 000 итераций и массиве в 1 000 000 элементов работает слишком долго....

Нужно ускорить или уменьшить код
Программа находит определенное количество подмножеств заданного множества Нужно ее либо ускорить либо уменьшить количество...

Нужно ускорить процесс
Делаю фильтр к таблице AdvStringGrid, на подобии Excel. При открытии фильтра нужно пробежаться по всем записям запроса, а внутри еще один...

Ускорить код)
Есть одна олимпиада на codeforces, но не в том дело. Так вот, одно из заданий (есть во вложениях) требует найти количество пар чисел из...


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

Или воспользуйтесь поиском по форуму:
21
Ответ Создать тему
Новые блоги и статьи
интеграция AnyLogic с самописным REST API и переход на Odoo
anaschu 03.07.2026
Успешная интеграция AnyLogic с самописным REST API и переход на промышленную Odoo WMS Сегодня проделал огромный путь от простой симуляции физических процессов до построения полноценной. . .
Поиск всех путей на ориентированном графе. Linux
dcc0 02.07.2026
Переработка старого кода из моей статьи. Через несколько переработок от PHP кода к C89 (надеюсь, 89). Но довольно запутанно получилось. Код для Linux. Но если убрать time и то, что с ним. . .
Сам себя обучал rest api
anaschu 02.07.2026
Педагогический лайфхак: Почему чистый REST API для ученика намного круче, чем готовые библиотеки Когда мы отказались от капризного JAR-файла AnyLogic и переписали код на стандартный HttpClient,. . .
rest api anylogic - выполнение модели на своём русском сайте
anaschu 02.07.2026
Как подружиться с AnyLogic Cloud API, победить провайдеров и развернуться Java-бэкенд в Docker на бесплатном хостинге: Двухдневный лог борьбы Всем привет! Хочу поделиться свежим (и довольно. . .
Где деньги лежат
kumehtar 02.07.2026
Это - японская подводная лодка I-52 (тип C2, кодовое имя Momi) вышла из Японии в марте 1944 года с миссией в оккупированную немцами Францию (Лорьян). Это была одна из «Янаги»-миссий по обмену. . .
Krabik для WoW 3.3.5a, многоязычный
AmbA 02.07.2026
Допилил бота, думаю что окончательно. Изменения: - добавлена многоязычность - добавлено снятие скриншотов - добавлено поддержание бафов хождения по воде (для жреца, дк и шамана) - и так, по. . .
Алиса нашла кучу ошибок компиляции и запуска в проекте, который без проблем компилировался и запускался)))
anaschu 30.06.2026
Я пока посмеюся, но завтра проверю. А вообще интерсно. Дал алисе файл, в котором точно нет ошибок компиляции и запуска, и попросил их найти. Нашла кучу))) Критические ошибки, мешающие компиляции и. . .
сукцессия 16. Общий обзор, в основном что бы другие ии поняли
anaschu 29.06.2026
# Передаточный документ: модель микоризной сукцессии (для нового чата) Этот документ предназначен для того, чтобы новый чат Claude мог продолжить работу без необходимости заново разбираться в. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru