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

Программа на С++Методо Гаусса - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Протабулировать ф-ю на промежутке от а к b с шагом n согласно вложению http://www.cyberforum.ru/cpp-beginners/thread29008.html
Прошу помогите решить написать программу. 1. Протабулировать ф-ю на промежутке от а к b с шагом n согласно вложению. 2. Задано число N. Сложить программу поиска “совершенствованных” чисел меньших за N. “совершенствованым” есть число, которое равно суме своих делителей, за исключением самого себя. Заранее благодарен.
C++ Протабулировать функцию в промежутке между а и b с шагом n Помогите пожалуйста написать программу Вот задание 1. Протабулювати функцію на проміжку від а до b з кроком n згідно додатку. 2. Задано деяке число N. Скласти програму пошуку “досконалих” чисел менших за N. “Досконалим” є число, яке дорівнює сумі своїх дільників, за винятком самого себе. http://www.cyberforum.ru/cpp-beginners/thread29006.html
Дан массив чисел C++
Дан массив чисел А(M). Создать из его элементов двумерный массив В, в каждой строке которого есть К элементов. Недостающие элементы последней строки массива В заполнить единицами.
C++ Заданна матрица
Заданна матрица K(A,B). Найти среднее геометрическое ее положительных элементов.
C++ Упорядочить последние L элементов массива по ненарастаниям (по неспадениям) (1<L<M) http://www.cyberforum.ru/cpp-beginners/thread28997.html
Задан массив чисел Q(M). Упорядочить его последние L элементов по ненарастаниям (по неспадениям) (1<L<M).
C++ Упорядочить заданный числовой массив Упорядочить заданный числовой массив X(M) в порядке спадания значений его элементов. подробнее

Показать сообщение отдельно
Анастасия Сонечко
1 / 1 / 0
Регистрация: 05.12.2008
Сообщений: 39
07.04.2009, 02:04     Программа на С++Методо Гаусса
[CPP] Реализован метод Гаусса.Предмет Численные методы. Может кто-то сталкивался.Но запустить не могу.Одно предупереждение об инициализации N.Среда Visual Studio 2008.Просьба помочь.Заранее спасибо.
.
#include<iostream>
using namespace std;
#include "locale.h"
#include <stdio.h>
#include <conio.h>
#include <math.h>
#define N 50
void chisl( int k, double mas[] [N + 1], int n, int otv[] );

int main( void )
{
setlocale(LC_ALL,"rus");
double mas[N] [N + 1];
double x[N]; //Корни системы
int otv[N]; //Отвечает за порядок корней
int i, j, k, n;
//Ввод данных
do
{
cout<<"Введите число уравнений: ";
cout<<"%d",&n;
if ( N < n )
cout<< "Очень большое число.Попробуйте еще раз\n";
}
while ( N < n );
cout<< "Уравнение системы:\n" ;
for ( i = 0; i < n; i++ )
for ( j = 0; j < n + 1; j++ )
cout<<"%lf", & mas[i] [j];
//Вывод введенной системы
cout<<"Уравненение системы:\n" ;
for ( i = 0; i < n; i++ )
{
for ( j = 0; j < n + 1; j++ )
cout<<"%7.2f ", mas[i] [j] ;
cout<<"\n" ;
}
//Сначала все корни по порядку
for ( i = 0; i < n + 1; i++ )
otv[i] = i;
//Прямой ход метода Гаусса
for ( k = 0; k < n; k++ )
{ //На какой позиции должен стоять главный элемент
chisl( k, mas, n, otv ); //Установка главного элемента
if ( fabs( mas[k] [k] ) < 0.0001 )
{
cout<<"У системы нет одного решения";
return ( 0 );
}
for ( j = n; j >= k; j-- )
mas[k] [j] /= mas[k] [k];
for ( i = k + 1; i < n; i++ )
for ( j = n; j >= k; j-- )
mas[i] [j] -= mas[k] [j] * mas[i] [k];
}
//Обратный ход
for ( i = 0; i < n; i++ )
x[i] = mas[i] [n];
for ( i = n - 2; i >= 0; i-- )
for ( j = i + 1; j < n; j++ )
x[i] -= x[j] * mas[i] [j];
//Вывод результата
cout<< "Вывод ответа на экран:\n";
for ( i = 0; i < n; i++ )
for ( j = 0; j < n; j++ )
if ( i == otv[j] )
{ //Расставляем корни по порядку
cout<<"%f\n", x[j];
break;
}
system("pause");
return 0;
}
//---------------------------------------------------------------------------
//Описание функции
//----------------------------------------------
void chisl( int k, double mas[] [N + 1], int n, int otv[] )
{
int i, j, i_max = k, j_max = k;
double temp;
//Ищем максимальный по модулю элемент
for ( i = k; i < n; i++ )
for ( j = k; j < n; j++ )
if ( fabs( mas[i_max] [j_max] ) < fabs( mas[i] [j] ) )
{
i_max = i;
j_max = j;
}
//Переставляем строки
for ( j = k; j < n + 1; j++ )
{
temp = mas[k] [j];
mas[k] [j] = mas[i_max] [j];
mas[i_max] [j] = temp;
}
//Переставляем столбцы
for ( i = 0; i < n; i++ )
{
temp = mas[i] [k];
mas[i] [k] = mas[i] [j_max];
mas[i] [j_max] = temp;
}
//Учитываем изменение порядка корней
i = otv[k];
otv[k] = otv[j_max];
otv[j_max] = i;
}
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 02:27. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru