Форум программистов
 

Восстановите пароль или Зарегистрируйтесь на форуме, о проблемах и с заказом рекламы пишите сюда - alarforum@yandex.ru, проверяйте папку спам!

Вернуться   Форум программистов > IT форум > Помощь студентам
Регистрация

Восстановить пароль

Купить рекламу на форуме - 42 тыс руб за месяц

Ответ
 
Опции темы Поиск в этой теме
Старый 17.05.2011, 16:18   #1
It is not me
 
Аватар для It is not me
 
Регистрация: 25.01.2011
Сообщений: 8
По умолчанию с++ решение матриц.

Здравствуйте.Задание:решение матриц методом гаусса.Помогите переделать эту программу под си из с++(насколько это возможно(самое просто вроде сам переделал)).Замечания по поводу исходного кода приветствуюсться,так как программа работает через пень колоду.
Код:
#include <conio.h>
#include <stdlib.h>
#include<iostream.h>
#include<stdio.h>
#define NUNKNOWN 4

 main()
{
    int colPos, rowPos;
    int i, j, k;
    double max;
    double temp;
    int m_nCols;
    int m_nRows;
    double** array;
    double*  array1;
    unsigned int* ListVar;
    double* x;

    m_nRows=4;
    m_nCols=m_nRows+1;
    array1=new double[m_nRows*m_nCols];
    array=new double*[m_nRows];
    for (i=0; i<m_nRows; i++)
    {
        *(array+i)=array1+i*m_nCols;
    }

    ListVar=new unsigned int[m_nCols-1];
    for (j=0; j<m_nCols-1; j++)
        ListVar[j]=j+1;

    x=new double[NUNKNOWN];

    for (i=0; i<m_nRows-1; i++)
        x[i]=i+1;

    for (i=0; i<4; i++)
        for (j=0;j<5; j++)
            scanf("%7.2lf",array[i][j]);
    for (k=0; k<m_nRows-1; k++)
    {
        colPos=rowPos=k;
        max=array[k][k];
        for (i=k; i<m_nRows; i++)
            for (j=k+1; j<m_nCols-1; j++)
                if (abs(array[i][j])>max)
                {
                    max=array[i][j];
                    rowPos=i;
                    colPos=j;
                }

        for (i=0; i<m_nRows; i++)
        {
            temp=array[i][k];
            array[i][k]=array[i][colPos];
            array[i][colPos]=temp;
        }

        for (j=0; j<m_nCols; j++)
        {
            temp=array[k][j];
            array[k][j]=array[rowPos][j];
            array[rowPos][j]=temp;
        }

        temp=ListVar[k];
        ListVar[k]=ListVar[colPos];
        ListVar[colPos]=temp;


        for (j=m_nCols-1; j>=0; j--)
        {
            array[k][j]/=array[k][k];

        }
        for (j=0; j<m_nCols; j++)
            array[k][j];
        for (i=k+1; i<m_nRows; i++)
            for (j=m_nCols-1; j>=0; j--)
                array[i][j]-=array[k][j]*array[i][k];

        for (i=0; i<m_nRows; i++)
        {
            for (j=0; j<m_nCols; j++)
                cout<<array[i][j]<<" ";
            printf("\n");
        }
        printf("\n");
    }

    double s=0;
    x[m_nRows-1]=array[m_nRows-1][m_nCols-1]/
                     array[m_nRows-1][m_nCols-2];
    for (i=m_nRows-2; i>=0; i--)
    {
        s=0;
        for (k=i+1; k<m_nRows; k++)
            s+=array[i][k]*x[k];
            x[i]=array[i][m_nCols-1]-s;
    }
    for (i=0; i<m_nRows; i++)
        cout<<"X"<<ListVar[i]<<"="<<x[i]<<endl;

    for (i=0; i<m_nRows; i++)
        delete [] array[i];
    delete [] array;
    delete [] array1;
    getch();
}
It is not me вне форума Ответить с цитированием
Ответ


Купить рекламу на форуме - 42 тыс руб за месяц



Похожие темы
Тема Автор Раздел Ответов Последнее сообщение
stl,Поиск Определителя матриц и решение линейных уравнений. igsxor Общие вопросы C/C++ 0 19.03.2011 21:52
Решение матриц Д.Ь.Я.В.О.Л Паскаль, Turbo Pascal, PascalABC.NET 0 22.12.2010 03:58
Решение матриц в Делфи. Катенка Помощь студентам 0 12.12.2010 15:56
Решение матриц в Паскале Baby33 Паскаль, Turbo Pascal, PascalABC.NET 0 20.01.2009 12:03
Решение матриц DJ DIMON Паскаль, Turbo Pascal, PascalABC.NET 1 08.12.2008 13:07