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

не получается составить программу

04.01.2011, 17:39. Показов 688. Ответов 4
Метки нет (Все метки)

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

решить методом Жордана Гауса
4,13 x1 -2,87x2- 1,94x3 +0,61x4= 0,32,
1,27x1+7,23x2-0,15x3 +1,71x4=-4,16,
0,19x1+2,75x2+3,14x3 -0,76x4= 2,33;
2,87x1+4,33x2-2,41x3-3,42x4=2,79;



Дана матрица A, порядка n. Найти А3
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
04.01.2011, 17:39
Ответы с готовыми решениями:

Не получается составить программу
У меня получилось что программа определяет точное попадание но у нас же есть сплеш S,как его выразить?Он же во все стороны идет а не в...

Не получается составить программу
Добрый день! Не получается составить программу, выдает ошибку и не понятно как ее исправить..помогите Функции такие: ...

Не получается составить программу(
Задача. написать программу, которая выводит элементы массива по формуле sin(x)*cos(x), где х-индекс массива

4
 Аватар для Минич
67 / 67 / 7
Регистрация: 26.11.2010
Сообщений: 123
05.01.2011, 12:52
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
122
123
124
125
126
127
128
129
/*
4,13x1-2,87x2-1,94x3+0,61x4= 0,32,
1,27x1+7,23x2-0,15x3+1,71x4=-4,16,
0,19x1+2,75x2+3,14x3-0,76x4= 2,33;
2,87x1+4,33x2-2,41x3-3,42x4= 2,79;
    Метод Гаусса — Жордана
1. Выбирают первый слева столбец матрицы, в котором есть хоть одно отличное от нуля значение.
2. Если самое верхнее число в этом столбце есть ноль, то меняют всю первую строку матрицы с другой строкой матрицы, где в этой колонке нет нуля.
3. Все элементы первой строки делят на верхний элемент выбранного столбца.
4. Из оставшихся строк вычитают первую строку, умноженную на первый элемент соответствующей строки, с целью получить первым элементом каждой строки (кроме первой) ноль.
5. Далее проводят такую же процедуру с матрицей, получающейся из исходной матрицы после вычёркивания первой строки и первого столбца.
6. После повторения этой процедуры n-1 раз получают верхнюю треугольную матрицу
7. Вычитаем из предпоследней строки последнюю строку, умноженную на соответствующий коэффициент, с тем, чтобы в предпоследней строке осталась только 1 на главной диагонали.
8. Повторяют предыдущий шаг для последующих строк. В итоге получают единичную матрицу и решение на месте свободного вектора (с ним необходимо проводить все те же преобразования).
9. Чтобы получить обратную матрицу, нужно применить все операции в том же порядке к единичной матрице.
*/
 
#include <iostream>
#include <iomanip>
using namespace std;
 
const int n = 4;
double arr[n][n+1] = { {4.13, -2.87, -1.94,  0.61,  0.32},
                       {1.27,  7.23, -0.15,  1.71, -4.16},
                       {0.19,  2.75,  3.14, -0.76,  2.33},
                       {2.87,  4.33, -2.41, -3.42,  2.79} };
 
int firstLeftColumn(int);   // Выбор первого слева столбца матрицы
int firstTopRow(int);       // Выбор перовой сверху строки не содержащей 0
void swapLines(int, int);   // Обмен строк
void calcArr(int);          // вычисление
void inputArr();            // вывод массив в консоль
 
void main()
{
    setlocale(LC_ALL, "Russian");
    inputArr();
    
    // 5. Далее проводят такую же процедуру с матрицей, получающейся из исходной матрицы
    // после вычёркивания первой строки и первого столбца.
    // 6. После повторения этой процедуры n − 1 раз получают верхнюю треугольную матрицу
    for (int i = 0; i < n; i++)
        calcArr(i); 
    
    // 7. Вычитаем из предпоследней строки последнюю строку, умноженную на соответствующий
    // коэффициент, с тем, чтобы в предпоследней строке осталась только 1 на главной диагонали.
    double temp;
    for (int k = n - 1; k > 0; k--) {
        for (int i = k - 1; i >= 0; i--) {  // цикл по предпоследним строкам
            temp = arr[i][k];
            for (int j = 0; j < n + 1; j++) // цикл по последним строкам
                arr[i][j] -= arr[k][j] * temp;
        }
    }
 
    // 8. Повторяют предыдущий шаг для последующих строк. В итоге получают единичную матрицу
    // и решение на месте свободного вектора (с ним необходимо проводить все те же преобразования).
 
    // 9. Чтобы получить обратную матрицу, нужно применить все операции в том же порядке  
    // к единичной матрице.
 
    inputArr();
    for (int i = 0; i < n; i++)
        cout << "x" << i + 1 << "=" << arr[i][n] << endl;
 
    system("pause");
}
 
int firstLeftColumn(int p)
{
    for (int j = p; j < n; j++)
        for (int i = p; i < n; i++)
            if(arr[i][j])
                return j;
}
 
int firstTopRow(int p, int column)
{
    for (int i = p + 1; i < n; i++)
        if(arr[i][column])
            return i;
}
 
void swapLines(int p, int line)
{
    double temp;
    for (int j = 0; j < n + 1; j++) {
            temp = arr[p][j];
            arr[p][j] = arr[line][j];
            arr[line][j] = temp;
        }
}
 
void calcArr(int p)
{   
    // 1. Выбрать первый слева столбец матрицы, в котором есть хоть одно отлично от нуля значение
    int numCol = firstLeftColumn(p);    // номер столбца
    
    // 2. Если самое верхнее число в этом столбце есть ноль, то меняют всю первую строку матрицы
    // с другой строкой матрицы, где в этой колонке нет нуля
    if (!arr[p][numCol])
        swapLines(p, firstTopRow(p, numCol));
 
    // 3. Все элементы первой строки делят на верхний элемент выбранного столбца
    double temp = arr[p][numCol];
    for (int j = 0; j < n + 1; j++)
        arr[p][j] /= temp;
    
    // 4. Из оставшихся строк вычитают первую строку, умноженную на первый элемент соответствующей
    // строки, с целью получить первым элементом каждой строки (кроме первой) ноль.
    for (int i = p + 1; i < n; i++) {
        temp = arr[i][p];
        for (int j = 0; j < n + 1; j++)
            arr[i][j] -= arr[p][j] * temp;
    }
}
 
void inputArr()
{
    cout << endl;
    for (int i = 0; i < n; i++) {
        for (int j = 0; j < n + 1; j++) {
            if (j == n)
                cout << " |";
            cout << setw(6) << arr[i][j];
        }
        cout << endl;
    }
}
1
0 / 0 / 0
Регистрация: 04.01.2011
Сообщений: 4
05.01.2011, 13:00  [ТС]
большое спасибо)) А по второй задаче кто-нибудь может прогу составить?
0
В астрале
Эксперт С++
 Аватар для ForEveR
8049 / 4806 / 655
Регистрация: 24.06.2010
Сообщений: 10,562
05.01.2011, 13:59
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
#include <iostream>
#include <ctime>
#include <cstdlib>
#include <iomanip>
 
int** mult_matr(int** first, int** second, int n)
{
    int** Arr;
    Arr=new int*[n];
    for(int i=0; i<n; ++i)
        Arr[i]=new int[n];
    for(int i=0; i<n; ++i)
    {
        for(int j=0; j<n; ++j)
        {
            Arr[i][j]=0;
            for(int k=0; k<n; ++k)
            {
                Arr[i][j]+=first[i][k]*second[k][j];
            }
        }
    }
    return Arr;
}
 
void print(int** Arr, int n)
{
    for(int i=0; i<n; ++i)
    {
        for(int j=0; j<n; ++j)
            std::cout<<std::setw(5)<<Arr[i][j]<<' ';
        std::cout<<'\n';
    }
    std::cout<<'\n';
}
 
void fill_rand(int** Arr, int n)
{
    int first, last;
    std::cout<<"Enter ranges for random fill: ";
    std::cin>>first>>last;
    for(int i=0; i<n; ++i)
    {
        for(int j=0; j<n; ++j)
        {
            Arr[i][j]=first+rand()%(last-first);
        }
    }
}
 
int main()
{
    srand(static_cast<unsigned>(time(0)));
    int** Arr;
    int n;
    std::cout<<"Enter n: ";
    std::cin>>n;
    Arr=new int*[n];
    for(int i=0; i<n; ++i)
        Arr[i]=new int[n];
    fill_rand(Arr, n);
    std::cout<<"A\n";
    print(Arr, n);
    int** secArr=mult_matr(Arr, Arr, n);
    std::cout<<"A^2\n";
    print(secArr, n);
    int** thirdArr=mult_matr(secArr, Arr, n);
    std::cout<<"A^3\n";
    print(thirdArr, n);
    for(int i=0; i<n; ++i)
        delete[] Arr[i];
    delete[] Arr;
    for(int i=0; i<n; ++i)
        delete[] secArr[i];
    delete[] secArr;
    for(int i=0; i<n; ++i)
        delete[] thirdArr[i];
    delete[] thirdArr;
    return 0;
}
1
0 / 0 / 0
Регистрация: 04.01.2011
Сообщений: 4
05.01.2011, 14:22  [ТС]
большое спс)))
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
05.01.2011, 14:22
Помогаю со студенческими работами здесь

Не получается составить программу в Eclipse
Описать класс «Множество», позволяющий выполнять основные операции: добавление и удаление элемента. Описываемый класс должен содержать: ...

Не получается составить программу вычисления арифметического выражения
Помогите пожалуйста! Составить программу вычисления арифметического выражения. В соответствии с условием установите необходимое количество...

Не получается составить программу вычисления значения функции
Помогите пожалуйста! Составить программу вычисления значения функции. В качестве f(x) использовать по выбору: sh(x), x2, ex. Отредактируйте...

Не получается составить программу используя процедуру или функцию.
Очень нужна помощь старших в решении задачи. Вот изображение вопроса:

Составить программу для записи в линейную таблицу X [1: k] только тех чисел, при делении которых на 5 и на 6 получается одна и та же целая часть.
Помогите пожалуйста написать массив... Задано линейную таблицу A , состоящая из положительных целых чисел. Составить программу для...


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

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
Настройки VS Code
Loafer 13.04.2026
{ "cmake. configureOnOpen": false, "diffEditor. ignoreTrimWhitespace": true, "editor. guides. bracketPairs": "active", "extensions. ignoreRecommendations": true, . . .
Оптимизация кода на разграничение прав доступа к элементам формы
Maks 13.04.2026
Алгоритм из решения ниже реализован на нетиповом документе, разработанного в конфигурации КА2. Задачи, как таковой, поставлено не было, проделанное ниже исключительно моя инициатива. Было так:. . .
Контроль заполнения и очистка дат в зависимости от значения перечислений
Maks 12.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: реализовать контроль корректности заполнения дат назначения. . .
Архитектура слоя интернета для сервера-слоя.
Hrethgir 11.04.2026
В продолжение https:/ / www. cyberforum. ru/ blogs/ 223907/ 10860. html Знаешь что я подумал? Раз мы все источники пишем в голове ветки, то ничего не мешает добавить в голову такой источник, который сам. . .
Подстановка значения реквизита справочника в табличную часть документа
Maks 10.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: при выборе сотрудника (справочник Сотрудники) в ТЧ документа. . .
Очистка реквизитов документа при копировании
Maks 09.04.2026
Алгоритм из решения ниже применим как для типовых, так и для нетиповых документов на самых различных конфигурациях. Задача: при копировании документа очищать определенные реквизиты и табличную. . .
модель ЗдравоСохранения 8. Подготовка к разному выполнению заданий
anaschu 08.04.2026
https:/ / github. com/ shumilovas/ med2. git main ветка * содержимое блока дэлэй из старой модели теперь внутри зайца новой модели 8ATzM_2aurI
Блокировка документа от изменений, если он открыт у другого пользователя
Maks 08.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа, разработанного в конфигурации КА2. Задача: запретить редактирование документа, если он открыт у другого пользователя. / / . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru