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

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

Войти
Регистрация
Восстановить пароль
 
Гашиш
0 / 0 / 0
Регистрация: 04.01.2011
Сообщений: 4
#1

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

04.01.2011, 17:39. Просмотров 362. Ответов 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
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
04.01.2011, 17:39     не получается составить программу
Посмотрите здесь:

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

Дано вещественное x. Вычислить z = f( x ), не получается составить код - C++
Дано вещественное x. Вычислить z = f( x ) http://ms.sfu-kras.ru/file.php/59/Lab_5/image014.gif (только в выражении вторая часть не...

Составить из данных слогов возможные слова и определить, получается ли заданное слово - C++
Даны три слога, каждый из двух букв и слово из 6 букв. Составить из слогов возможные слова и определить, получается ли заданное слово....

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

Не получается скомпилировать программу - C++
Это всего лишь кусок кода, решил его протестить перед последующим продолжением. Запускаю в консоле все пусто, компилятор ни на что не...

Не получается собрать программу - C++
Здравствуйте ! Использую "Geany" в ОС "Linuxmint 17" Столкнулся с такой проблемой, пытаюсь создать класс в двух отдельных файлах ".cpp"...

не получается скомпилировать программу в Dev-C++ - C++
я написал код ,сто раз перепроверил, но не компилируется! подскажите что в коде неверно, вот код: #include <stdio.h> #include...

В С++ 2012 не получается отладить программу - C++
На с++ 2012 г. при отладке выскакивает окно присоединение к процессору, из-за чего и не работает программа. Не знаю, что делать. Как можно...

Не получается дописать программу по массивам - C++
Задание: В каждой строке матрицы Т найти количество делящихся на 3, и записать эти числа в вектор. Сделать сортировки вектора по...

Не получается правильно построить программу - C++
Доброго времени суток. Есть код программы: #include <cstdlib> #include <iostream> using namespace std; int main(int argc,...


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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Минич
66 / 66 / 3
Регистрация: 26.11.2010
Сообщений: 123
05.01.2011, 12:52     не получается составить программу #2
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;
    }
}
Гашиш
0 / 0 / 0
Регистрация: 04.01.2011
Сообщений: 4
05.01.2011, 13:00  [ТС]     не получается составить программу #3
большое спасибо)) А по второй задаче кто-нибудь может прогу составить?
ForEveR
В астрале
Эксперт С++
7969 / 4731 / 320
Регистрация: 24.06.2010
Сообщений: 10,539
Завершенные тесты: 3
05.01.2011, 13:59     не получается составить программу #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
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;
}
Гашиш
0 / 0 / 0
Регистрация: 04.01.2011
Сообщений: 4
05.01.2011, 14:22  [ТС]     не получается составить программу #5
большое спс)))
Yandex
Объявления
05.01.2011, 14:22     не получается составить программу
Ответ Создать тему
Опции темы

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