Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.80/5: Рейтинг темы: голосов - 5, средняя оценка - 4.80
0 / 0 / 0
Регистрация: 30.11.2015
Сообщений: 83

в чем ошибка ? не считает y[n]

23.04.2017, 17:32. Показов 1069. Ответов 15
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
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
#include <iostream>
 
using namespace std;
 
int main()
{
    const int n = 3;
    double sum = 0;
    double A[n][n], L[n][n], U[n][n], R[n][n];
    double f[n];
 
    //задаем матрицу A[][] ...
 
    for (int i = 0; i < n; i++)
    {
        for (int j = 0; j < n; j++)
        {
            cout << "\nA[" << i << "][" << j << "]: ";
            cin >> A[i][j];
 
            L[i][j] = 0;
            U[i][j] = 0;
 
            if (i == j)
                U[i][j] = 1;
        }
    }
    cout << endl;
 
    //==============================================
 
    //находим первый столбец L[][] и первую строку U[][]
 
    for (int i = 0; i < n; i++)
    {
        L[i][0] = A[i][0];
        U[0][i] = A[0][i] / L[0][0];
    }
 
    //дальше вычисляем L[][], U[][] по формуле
 
    for (int i = 1; i < n; i++)
    {
        for (int j = 1; j < n; j++)
        {
            if (i >= j) //нижний треугольник
            {
                sum = 0;
                for (int k = 0; k < j; k++)
                    sum += L[i][k] * U[k][j];
 
                L[i][j] = A[i][j] - sum;
            }
            else // верхний
            {
                sum = 0;
                for (int k = 0; k < i; k++)
                    sum += L[i][k] * U[k][j];
 
                U[i][j] = (A[i][j] - sum) / L[i][i];
            }
        }
    }
 
    for (int i = 0; i < n; i++)
    {
        cout << "\nf[" << i << "]: ";
        cin >> f[i];
    }
    cout << endl;
 
    //====================================================
    cout << "\n\nFirst matrix:" << endl;
    for (int i = 0; i < n; i++) // вывод матрицы А
    {
        for (int j = 0; j < n; j++)
            cout << "  " << A[i][j] << "   ";
        cout << "\n\n";
    }
 
    cout << "\n\nL matrix:" << endl; 
    for (int i = 0; i < n; i++)
    {
        for (int j = 0; j < n; j++)
            cout << "  " << L[i][j] << "   ";
        cout << "\n\n";
    }
 
    cout << "\n\nU matrix: " << endl; 
    for (int i = 0; i < n; i++)
    {
        for (int j = 0; j < n; j++)
            cout << "  " << U[i][j] << "   ";
        cout << "\n\n";
    }
 
    cout << "\n\nf vector: " << endl;
    for (int j = 0; j < n; j++)
    {
        cout << "  " << f[j] << endl;
    }
    cout << endl;
 
    //====================================================
    
    double y[n];    //Находим y[n] по формуле (2.11)
    for (int i = 0; i < n; i++) {
        sum = 0;
        for (int k = 0; k < i; k++) {
            sum += L[i][k] * y[k];
            y[i] = f[i] - sum;
        }
        
        cout << y[n];
    }
    cout << endl;
 
 
    system("pause");
    return 0;
}
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
23.04.2017, 17:32
Ответы с готовыми решениями:

Не считает вообще, в чем ошибка?
Помогите найти ошибку unit Unit1; //Даны массивы а и b, состоящие из n элементов каждый. //Получите массив с, где ck = ak +...

Не считает. Что не так. В чем ошибка
Не считает. Что не так?

не правильно считает сумму в чем ошибка
#include &quot;stdafx.h&quot; #include &lt;iostream&gt; #include &lt;math.h&gt; int fak(int K){ int s; for(s=1;K&gt;0;K--) ...

15
 Аватар для Новичок
1682 / 1098 / 489
Регистрация: 17.07.2012
Сообщений: 5,360
23.04.2017, 17:36
Телепат я пока еще начинающий, но попробую угадать что вы хотите.
C++
114
cout << y[i] << endl;
0
0 / 0 / 0
Регистрация: 30.11.2015
Сообщений: 83
23.04.2017, 17:43  [ТС]
Новичок, выводит какие-то странные числа, но никак не те, что мне нужны..
0
1719 / 568 / 187
Регистрация: 12.03.2016
Сообщений: 2,169
23.04.2017, 20:35
Цитата Сообщение от El_i_z_a_b_e_th Посмотреть сообщение
выводит какие-то странные числа,
Все правильно, так и должно.
В строке 106 объявляете массив y[n], а чему равны y[0],y[1],y[2] неизвестно. Поэтому программа дальше (строки 110 - 114) и выводит эту "белиберду".
0
0 / 0 / 0
Регистрация: 30.11.2015
Сообщений: 83
23.04.2017, 21:28  [ТС]
мановар, программа должна вычислить эти значения и вывести
0
1719 / 568 / 187
Регистрация: 12.03.2016
Сообщений: 2,169
23.04.2017, 21:36
Цитата Сообщение от El_i_z_a_b_e_th Посмотреть сообщение
программа должна вычислить эти значения и вывести
Спасибо за подсказку
В строке 110 при первом проходе во втором цикле при i=0 и к=0
получите sum += L[0][0] * y[0]; где L[0][0] вычислено за ранее, а y[0] нет, оно неизвестно
и программа подставляет вместо него "кракозябру".
0
0 / 0 / 0
Регистрация: 30.11.2015
Сообщений: 83
23.04.2017, 21:40  [ТС]
мановар, а как тогда можно изменить код, чтобы он заработал правильно?

Добавлено через 14 секунд
мановар, подскажите пожалуйста
0
1719 / 568 / 187
Регистрация: 12.03.2016
Сообщений: 2,169
23.04.2017, 21:46
Что бы правильно подсказать надо знать задание.
К примеру замените строку 106 на
double y[] = { 0,0,0 };
и увидите разницу
0
0 / 0 / 0
Регистрация: 30.11.2015
Сообщений: 83
23.04.2017, 21:56  [ТС]
мановар, просто у меня эти значения необходимо для нахождения корней системы

Добавлено через 2 минуты
мановар, а задание: решить методом холецкого(lu-разложение) метод написан правильно, мне просто дальше нужно дорешать, чтобы получить корни системы

Добавлено через 5 минут
мановар, если брать конкретный пример, то у меня матрица А
1 1 1
5 3 -2
-3 -4 6
А=UL
U: 1 1 1
0 1 7/2
0 0 1
L: 1 0 0
5 -2 0
-3 -1 25/2

это все правильно находит, но дальше мне нужно решить системы Ly=f и Ux=y, что я сейчас и пытаюсь сделать...

Добавлено через 1 минуту
где f=4,9,-5
0
1719 / 568 / 187
Регистрация: 12.03.2016
Сообщений: 2,169
23.04.2017, 22:01
Как я понял f[0]=f[1]=f[2]=1
Какой ответ должен быть?
0
0 / 0 / 0
Регистрация: 30.11.2015
Сообщений: 83
23.04.2017, 22:04  [ТС]
мановар, Ly=f: y1=4, y2=11/2, y3=1
Ux=y: x1=1, x2 =2, x3=1

Добавлено через 53 секунды
мановар, в результате должно выводить все х
0
1719 / 568 / 187
Регистрация: 12.03.2016
Сообщений: 2,169
23.04.2017, 22:21
El_i_z_a_b_e_th, надо разбираться в этом методе. Я его не знаю. Уже поздно.

Добавлено через 4 минуты
Если есть нормальная ссылка по реализации этого метода в интернете, то скиньте.
0
0 / 0 / 0
Регистрация: 30.11.2015
Сообщений: 83
23.04.2017, 22:30  [ТС]
мановар, https://habrahabr.ru/sandbox/35982/

Добавлено через 1 минуту
мановар, но это не очень такое.. я по книге писала
0
1719 / 568 / 187
Регистрация: 12.03.2016
Сообщений: 2,169
24.04.2017, 08:09
El_i_z_a_b_e_th, на сколько успел разобраться в теории у Вас не совсем верная формула для вычисления y[n].
Для нахождения y[n] из L-матрицы попробуйте так
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
double y[n];    //Находим y[n] по формуле (2.11)
 
 
    for (int i = 0; i < n; i++) {
        sum = 0;
        for (int k = 0; k < i; k++) {
            sum += L[i][k] * y[k];
    //      y[i] = f[i] - sum;
        }
        y[i] = (f[i] - sum)/L[i][i];
 
        cout << y[i] << "   ";
    }
Теперь осталось найти x[n] из U-матрицы. (Посмотрю еще теорию может что по лучше найду).
0
Любитель чаепитий
 Аватар для GbaLog-
3745 / 1801 / 566
Регистрация: 24.08.2014
Сообщений: 6,020
Записей в блоге: 1
24.04.2017, 09:06
Цитата Сообщение от мановар Посмотреть сообщение
и программа подставляет вместо него "кракозябру".
программа не подставляет туда ничего, программа просто не чистит память, которую заняла.
т.к. за собой ни одна программа не убирает, эта память остаётся с теми же значениями, что и были при освобождении.
0
1719 / 568 / 187
Регистрация: 12.03.2016
Сообщений: 2,169
24.04.2017, 13:30
GbaLog-, пусть будет по Вашему, не хочется возвращаться к вчерашним измышлениям, тем более, что на самом деле во втором цикле первая итерация пропускается и y[0] там не нужно для расчета, а дальше как я писал идет неправильная формула, что и приводит к таким результатам. В этом случае мне тяжело было судить о программе без теории (сказывается недостаток опыта. В мае будет год как взялся за программирование). Когда разобрался в методе, все встало на свои места. Предложил решение. Думаю ТС разберется что к чему. Вот вроде как и Ux=y допилил. Надо еще раз перепроверить.

Добавлено через 3 часа 47 минут
Цитата Сообщение от El_i_z_a_b_e_th Посмотреть сообщение
а задание: решить методом холецкого
Как я понял Ваша программа реализует решение СЛАУ методом LU - разложения (что в принципе и указано в ссылке).
В методе Холецкого другой подход к формированию матриц.
https://ru.wikipedia.org/wiki/Разложение_Холецкого
http://studopedia.ru/9_85250_metod-holetskogo.html
Определяйтесь с методом.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
24.04.2017, 13:30
Помогаю со студенческими работами здесь

В чем ошибка, не считает...ответ выдает по нулям((((
#include &lt;stdio.h&gt; #include &lt;windows.h&gt; #include &lt;math.h&gt; char buf ; char*RUS(const char*text) { CharToOem(text,buf); ...

Не понимаю в чем ошибка. Неправильно считает количество повторений
Вот код. Программа должна считывать 4 числа, и выводить кол-во повторений. Она выводит, но неправильно, когда 2 повторения выводит 6. ...

не считает сумму ниже побочной диагонали, в чем ошибка?
Вот сам код,где ошибка?:( #include &quot;stdafx.h&quot; #include &quot;iostream&quot; #include &lt;iomanip&gt; double **mass; int i,j,n,sum; using...

В чем ошибка?Считает сумму, но забывает всегда по 1 цифру
#include &lt;stdio.h&gt; #include &lt;conio.h&gt; #include &lt;locale&gt; int main() { setlocale (0,&quot;&quot;); int n, a , sum=0; printf(&quot;Введите...

Геометрический метод Монте-Карло(считает интеграл) не могу понять в чем ошибка
Геометрический метод Монте-Карло(считает интеграл) не могу понять в чем ошибка, вроде делаю все по алгоритму: Геометрический...


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

Или воспользуйтесь поиском по форуму:
16
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование . \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json> Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом. # Check if. . .
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так: https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347 Основана на STM32F303RBT6. На борту пять. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru