www.vorhilfe.de
- Förderverein -
Der Förderverein.

Gemeinnütziger Verein zur Finanzierung des Projekts Vorhilfe.de.
Hallo Gast!einloggen | registrieren ]
Startseite · Mitglieder · Impressum
Forenbaum
^ Forenbaum
Status VH e.V.
  Status Vereinsforum

Gezeigt werden alle Foren bis zur Tiefe 2

Navigation
 Startseite...
 Suchen
 Impressum
Das Projekt
Server und Internetanbindung werden durch Spenden finanziert.
Organisiert wird das Projekt von unserem Koordinatorenteam.
Hunderte Mitglieder helfen ehrenamtlich in unseren moderierten Foren.
Anbieter der Seite ist der gemeinnützige Verein "Vorhilfe.de e.V.".
Partnerseiten
Weitere Fächer:

Open Source FunktionenplotterFunkyPlot: Kostenloser und quelloffener Funktionenplotter für Linux und andere Betriebssysteme
Forum "C/C++" - symmetrische Matrix
symmetrische Matrix < C/C++ < Programmiersprachen < Praxis < Informatik < Vorhilfe
Ansicht: [ geschachtelt ] | ^ Forum "C/C++"  | ^^ Alle Foren  | ^ Forenbaum  | Materialien

symmetrische Matrix: Frage (beantwortet)
Status: (Frage) beantwortet Status 
Datum: 20:46 Do 22.05.2008
Autor: ElisabethWallner

Aufgabe
Eine Matrix A in R nxn ist symmetrisch, falls Ajk=Akj für alle j,k von 1....n gilt. Schreiben Sie eine Funktion issymmetric, die eine Matrix A auf Symmetrie überprüft(Rückgabewert 1 bei Symmetrie und 0 bei Nicht-Symmetrie). Schreiben Sie ein aufrufendes Hauptprogramm, in dem A eingelesen wird und ausgegeben wird, ob A symmetrisch ist oder nicht. Speichern Sie die Matrix spaltenweise. Die Dimension n in N der Matrix soll eine Konstante im Hauptprogramm, aber ein Parameter der Funktion issymmetric sein.  

1: #include <stdio.h>
2: #define N 3
3:
4: int issymmetric(double A[],int n)
5: {
6: int j,k;
7: double tmp;
8:
9: for(j=0;j<n;++j)  for(k=j+1;k<n;++k)
10: tmp=A[j+k*n];
11: A[j+k*n]=A[k+j*n];
12: A[k+j*n]=tmp;
13:
14: for(j=0;j<n;++j)  for(k=j+1;k<n;++k)
15: { if(A[j+k*n]!=A[k+j*n])
16: return 0;
17: else
18: return 1;
19: }
20:
21: main()
22: {
23: int j,k,n;
24: double A[N*N];
25:
26: for(j=0;j<N;++j) for(k=j+1;k<N;++k)
27: { printf("A(%d %d)",j,k);
28: scanf("%lf",&A[j+k*n] ); }
29:
30: printf("sym=%d\n",issymmetric(A,n));
31: }


Ich grüble schon ewig.

Ich habe diese Frage auch in folgenden Foren auf anderen Internetseiten gestellt:

https://tuwis.tuwien.ac.at/zope/_ZopeId/52601658A3X5y91I9UQ/tpp/trusted/student/forum/dispMsg?num=101275&sem=2008S&msgid=439233&sort=thread

        
Bezug
symmetrische Matrix: Antwort
Status: (Antwort) fertig Status 
Datum: 16:48 Fr 23.05.2008
Autor: Gilga

Speichern Sie die Matrix spaltenweise:
Bestimmt nicht alles in einem Vektor speichern!
double A[N][N]; verwenden und spaltenweise einlesen!

26: for(j=0;j<N;++j) for(k=j+1;k<N;++k)
Netter Versuch: mit dieser Schleife kann man nur folgende Elemente der Matrix speichern: (=>nur brauchbar wenn man eine symmetrische MAtrix einlesen möchte). Hier muss man aber auf Symmetrie überprüfen.

Schreibe mal deine Schleifen um und verwende zum speichern
Bedenke Ajk=Akj für alle j,k von 1....n

X X X X X
   X X X X
      X X X
         X X
            X

Bezug
Ansicht: [ geschachtelt ] | ^ Forum "C/C++"  | ^^ Alle Foren  | ^ Forenbaum  | Materialien


^ Seitenanfang ^
ev.vorhilfe.de
[ Startseite | Mitglieder | Impressum ]