Školní projekt v C/C++ Maticové operace – C / C++ – Fórum – Programujte.com
 x   TIP: Přetáhni ikonu na hlavní panel pro připnutí webu

Školní projekt v C/C++ Maticové operace – C / C++ – Fórum – Programujte.comŠkolní projekt v C/C++ Maticové operace – C / C++ – Fórum – Programujte.com

 

Luboš550
Duch
13. 12. 2014   #1
-
0
-

Dobrý večer,
mam projekt do školy a už nevím jak dal a tímto bych chtěl vás zde požádat o pomoc sedím nad tím dnem a noci a nemůžu se hnout z místa.

Zadání:
Program přijímá na vstupu matici zadanou po řádcích, a to buď z klávesnice, nebo souboru. Vstup z klávesnice je průběžně validován, a průběžně je plněno dvourozměrné dynamicky alokované pole. Při vstupu ze souboru se kontroly (validace) neprovádí. Nad maticí v paměti lze zavolat Gaussovu eliminační metodu (implementujte ji jako funkci, jejímž konstantním vstupem je ukazatel na vstupní pole, výstupem ukazatel na nově vytvořené pole v trojúhelníkovém tvaru s vypočtenými hodnotami nezávislých proměnných, pokud to hodnost rozšířené matice dovolí). Program umožňuje výstup do HTML souboru, obsahující výslednou matici (použijte HTML tagy, jinak se formátem nijak zvlášť nezabývejte), pod maticí budou hodnoty nezávislých proměnných. Dalším možným výstupem bude výpis matice a hodnoty jejího determinantu, pokud to hodnost matice dovolí.

Můj kod:

// Maticove oprace.cpp : Defines the entry point for the console application.
//

//#include "stdafx.h"
#include <stdio.h>
#include <iostream>
#include<math.h>
#include<iomanip>
using namespace std;

float GEM(float *a[],float *b[], int N, int M)
{
	for (int i = 0; i < N; i++)
	{
		for (int j = 0; j < M; j++)
		{
			b[i][j] = a[i][j];
		}
	}

	int max = 0;
	float pom;
	for (int i = 0; i<N; i++)              //nalezení pivota
	{
		for (int j = i + 1; j<N; j++)
        {
            if (fabs(b[j][i])>fabs(b[i][i]))
                max = j;
        }

		for (int k = i; k<M; k++)
		{
			pom = b[i][k];
			b[i][k] = b[max][k];
			b[max][k] = pom;
		}

		for (int j = i + 1; j<N; j++)
        {
            for (int k = N; k >= i; k--)
            {
                b[j][k] = b[j][k] - b[i][k] * b[j][i] / b[i][i];
            }
        }
	}
/************************************************************************/
    float r[N];
    int res = M-1;
    for(int i=0; i<N; i++)
       r[i]=b[i][res];
    int pr = 0;
    if(pr==0)
    {
     for(int j=N-1; j>=0; j--)
     {
       pom=0;
       for(int k=j+1; k<=N; k++)
           pom=pom+b[j][k]*r[k];
       r[j]=(b[j][N]-pom)/b[j][j];
     }
   }
   for (int j = 0; j < M-1; j++)
		{
			printf("x%d = %5.3f \n",j+1, r[j]);
		}
/************************************************************************/
	return **b;
}
void vypismat(float *a[],int N,int M)
{
    for (int i = 0; i<N; i++)
	{//vypisuje prvky, když dojde na konec řadky, odřádkuje
		for (int j = 0; j<M; j++)
		{
			printf(" %5.3f ", a[i][j]);
			if (j == M - 1)
				printf("\n");

			if (j == N-1)
				printf(" | ");
		}
	}
}
void naplmatici(float *a[],int N,int M)
{
    int res;
    printf("Vyplnte matici:\n");
	for (int x = 0; x < N; x++)
	{
		for (int j = 0; j < M; j++)
		{
			scanf("%f", &a[x][j]);
		}

	}
}
int main(int argc)
{
	int N, M;
	printf("zadejte počet řádku matice:");
	scanf("%d", &N);
	printf("zadejte počet sloupcu matice:");
	scanf("%d", &M);
	/*****************************************************************/
	float**pole;
	pole = new float*[N];
	for (int i = 0; i < N; i++)
	{
		pole[i] = new float[M];
	}
	naplmatici(pole,N,M);
	/************************************************************************/
	float**pole1;
	pole1 = new float*[N];
	for (int i = 0; i < N; i++)
	{
		pole1[i] = new float[M];
	}
	GEM(pole, pole1, N, M);
	/************************************************************/
	vypismat(pole,N,M);
	printf("******************************************************\n");
	vypismat(pole1,N,M);

/*************************************************************/


/*************************************************************/
	for (int i = 0; i<N; i++) {
		delete[] pole[i];
		delete[] pole1[i];
	}
	delete[] pole;
	delete[] pole1;

	return 0;
}

1) Chtěl bych, lepe vyřešit Gaussovu eliminační metodu nebo bych jí spíš chtěl vyřešit podle zadání.

2) Chtěl bych taky načítat s csv souboru což absolutně nevím jak sem začátečník.

Nahlásit jako SPAM
IP: 89.203.209.–
Zjistit počet nových příspěvků

Přidej příspěvek

Toto téma je starší jak čtvrt roku – přidej svůj příspěvek jen tehdy, máš-li k tématu opravdu co říct!

Ano, opravdu chci reagovat → zobrazí formulář pro přidání příspěvku

×Vložení zdrojáku

×Vložení obrázku

Vložit URL obrázku Vybrat obrázek na disku
Vlož URL adresu obrázku:
Klikni a vyber obrázek z počítače:

×Vložení videa

Aktuálně jsou podporována videa ze serverů YouTube, Vimeo a Dailymotion.
×
 
Podporujeme Gravatara.
Zadej URL adresu Avatara (40 x 40 px) nebo emailovou adresu pro použití Gravatara.
Email nikam neukládáme, po získání Gravatara je zahozen.
-
Pravidla pro psaní příspěvků, používej diakritiku. ENTER pro nový odstavec, SHIFT + ENTER pro nový řádek.
Sledovat nové příspěvky (pouze pro přihlášené)
Sleduj vlákno a v případě přidání nového příspěvku o tom budeš vědět mezi prvními.
Reaguješ na příspěvek:

Uživatelé prohlížející si toto vlákno

Uživatelé on-line: 0 registrovaných, 60 hostů

Podobná vlákna

Školní projekt — založil Honza

Školní projekt v C — založil sputnikone

Školní projekt — založil Asimka

Školní projekt (Databáze) — založil Patrik Štěrba

Moderátoři diskuze

 

Hostujeme u Českého hostingu       ISSN 1801-1586       ⇡ Nahoru Webtea.cz logo © 20032025 Programujte.com
Zasadilo a pěstuje Webtea.cz, šéfredaktor Lukáš Churý