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

Не понятно - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ перегрузка объектов http://www.cyberforum.ru/cpp-beginners/thread212535.html
Дан класс Окружность, включающий в себя радиус, диаметр, площадь и длину дуги. Указать все необходимые функции инициализации и доступа к объектам класса. Перегрузить для объектов класса операторы +, - , /, ++ ,-- ,&& ,|| , ==, != относительно радиуса и диаметра
C++ Списки Вот есть задание...всё вроде бы сделал,но работает не правильно...не правильно добавляет элементы...помогите разобраться... Записи в линейном списке содержат ключевое поле типа int. Сформировать однонаправленный список. Удалить из него элемент после элемента с заданным номером, добавить элемент после элемента с заданным номером; #include<iostream> using namespace std; struct node { ... http://www.cyberforum.ru/cpp-beginners/thread212534.html
C++ график функции
Исследовать область определения функции и построить её график для произвольных значений параметров на заданном интервале (интервал и параметры задаются интерактивно) Кардиоида: x=acost(1+cost) y=asint(1+cost) a>0,t E[0,2П)
C++ стринговые константы
Ввести стринговую константу. Превратить ее в трьохдиагональну матрицу, присвоив для этого нули соответствующим элементам. Транспонировать полученную матрицу относительно середины (средней строки). Конкатенировать две строки полученной матрицы. Вывести все промежуточные и конечные результаты.
C++ Кто знает,ответьте) http://www.cyberforum.ru/cpp-beginners/thread212521.html
Как реализованы строки с языке программирования Си? Почему строки называют нуль-терминальными? Сколько байт памяти необходимо для корректного хранения строки «Привет!» (без кавычек? Нарисуйте блок-схему и объясните принцип работы алгоритма вычисления длины строки. Как произвести склейку двух строк? Нарисуйте блок-схему и объясните принцип работы алгоритма подсчета цифр в тексте. Как...
C++ Выделение памяти под масссив Как занести данные в двумерный массив с клавиатуры? пользователь должен сам ввести размерность подробнее

Показать сообщение отдельно
silent_1991
Эксперт C++
4938 / 3014 / 149
Регистрация: 11.11.2009
Сообщений: 7,024
Завершенные тесты: 1
16.12.2010, 19:37     Не понятно
Mayonez, это пишется за 30 минут, благо алгоритм уже больше 300 лет существует - метод Гаусса в помощь.

Добавлено через 23 минуты
Вот, что-то вроде этого:

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
#include <iostream>
 
void swap(double &a, double &b)
{
    double temp = a;
    a = b;
    b = temp;
}
 
void Gauss(double **A, double *B, unsigned dim)
{
    for (unsigned k = 0; k < dim; ++k)
    {
        if (A[k][k] == 0.0)
        {
            for (unsigned i = k + 1; i < dim; ++i)
            {
                if (A[i][k] != 0.0)
                {
                    for (unsigned j = 0; j < dim; ++j)
                        swap(A[i][j], A[k][j]);
 
                    swap(B[i], B[k]);
 
                    break;
                }
            }
        }
 
        double div = A[k][k];
 
        for (unsigned j = 0; j < dim; ++j)
            A[k][j] /= div;
 
        B[k] /= div;
 
        for (unsigned i = k + 1; i < dim; ++i)
        {
            double multi = A[i][k];
 
            for (unsigned j = 0; j < dim; ++j)
                A[i][j] -= multi * A[k][j];
 
            B[i] -= multi * B[k];
        }
    }
 
    for (unsigned k = dim - 1; k > 0; --k)
    {
        for (unsigned i = k - 1; i + 1 > 0; --i)
        {
            double multi = A[i][k];
 
            for (unsigned j = 0; j < dim; ++j)
                A[i][j] -= multi * A[k][j];
 
            B[i] -= multi * B[k];
        }
    }
}
 
int main()
{
    double *A[4];
    double B[4] = {4.3, 6.8, -1.8, 7.2};
 
    for (int i = 0; i < 4; ++i)
        A[i] = new double [4];
 
    A[0][0] = 4.4; A[0][1] = -2.5; A[0][2] = 19.2; A[0][3] = -10.8;
    A[1][0] = 5.5; A[1][1] = -9.3; A[1][2] = -14.2; A[1][3] = 13.2;
    A[2][0] = 7.1; A[2][1] = -11.5; A[2][2] = 5.3; A[2][3] = -6.7;
    A[3][0] = 14.2; A[3][1] = 23.4; A[3][2] = -8.8; A[3][3] = 5.3;
 
    Gauss(A, B, 4);
 
    std::cout << "X = {"
              << B[0] << ", "
              << B[1] << ", "
              << B[2] << ", "
              << B[3]
              << "}" << std::endl;
 
    for (int i = 0; i < 4; ++i)
        delete [] A[i];
 
    return 0;
}
Добавлено через 37 минут
Что-то я второе сначала и не заметил)))

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
#include <iostream>
 
void transpose(double **A, double **result, int rows, int cols)
{
    for (int i = 0; i < cols; ++i)
        for (int j = 0; j < rows; ++j)
            result[i][j] = A[j][i];
}
 
void multiply(double **A, double **B, double **result, int n, int m, int p)
{
    for (int i = 0; i < n; ++i)
    {
        for (int j = 0; j < p; ++j)
        {
            result[i][j] = 0.0;
 
            for (int k = 0; k < m; ++k)
                result[i][j] += A[i][k] * B[k][j];
        }
    }
}
 
int main()
{
    double **Y, **X, **XT;
    int n, m;
 
    std::cout << "Enter n: ";
    std::cin >> n;
    std::cout << "Enter m: ";
    std::cin >> m;
 
    Y = new double *[n];
 
    for (int i = 0; i < n; ++i)
        Y[i] = new double [n];
 
    X = new double *[n];
 
    for (int i = 0; i < n; ++i)
        X[i] = new double [m];
 
    XT = new double *[m];
 
    for (int i = 0; i < m; ++i)
        XT[i] = new double [n];
 
    for (int i = 0; i < n; ++i)
    {
        for (int j = 0; j < m; ++j)
        {
            std::cout << "X[" << i << "][" << j << "] = ";
            std::cin >> X[i][j];
        }
    }
 
    transpose(X, XT, n, m);
    multiply(X, XT, Y, n, m, n);
 
    for (int i = 0; i < n; ++i)
    {
        for (int j = 0; j < n; ++j)
            std::cout << Y[i][j] << "  ";
 
        std::cout << std::endl;
    }
 
    for (int i = 0; i < n; ++i)
        delete [] Y[i];
 
    delete [] Y;
 
    for (int i = 0; i < n; ++i)
        delete [] X[i];
 
    delete [] X;
 
    for (int i = 0; i < m; ++i)
        delete [] XT[i];
 
    delete [] XT;
 
    return 0;
}
 
Текущее время: 02:11. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru