matheraum.de
Raum für Mathematik
Offene Informations- und Nachhilfegemeinschaft

Für Schüler, Studenten, Lehrer, Mathematik-Interessierte.
Hallo Gast!einloggen | registrieren ]
Startseite · Forum · Wissen · Kurse · Mitglieder · Team · Impressum
Forenbaum
^ Forenbaum
Status Schulmathe
  Status Primarstufe
  Status Mathe Klassen 5-7
  Status Mathe Klassen 8-10
  Status Oberstufenmathe
    Status Schul-Analysis
    Status Lin. Algebra/Vektor
    Status Stochastik
    Status Abivorbereitung
  Status Mathe-Wettbewerbe
    Status Bundeswettb. Mathe
    Status Deutsche MO
    Status Internationale MO
    Status MO andere Länder
    Status Känguru
  Status Sonstiges

Gezeigt werden alle Foren bis zur Tiefe 2

Navigation
 Startseite...
 Neuerdings beta neu
 Forum...
 vorwissen...
 vorkurse...
 Werkzeuge...
 Nachhilfevermittlung beta...
 Online-Spiele beta
 Suchen
 Verein...
 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
StartseiteMatheForenAlgorithmen und Datenstrukturenasymptotische Aufwandsabschätz
Foren für weitere Schulfächer findest Du auf www.vorhilfe.de z.B. Informatik • Physik • Technik • Biologie • Chemie
Forum "Algorithmen und Datenstrukturen" - asymptotische Aufwandsabschätz
asymptotische Aufwandsabschätz < Algor.+Datenstr. < Theoretische Inform. < Hochschule < Informatik < Vorhilfe
Ansicht: [ geschachtelt ] | ^ Forum "Algorithmen und Datenstrukturen"  | ^^ Alle Foren  | ^ Forenbaum  | Materialien

asymptotische Aufwandsabschätz: Frage (beantwortet)
Status: (Frage) beantwortet Status 
Datum: 13:43 Di 23.11.2004
Autor: mausi

hat jemand ne ahnung wie man das berechnet für diesen programmausschnitte?

static int unwichtig(int n){
   int ergebnis=0;
   for(int i=0; i < n; i++){
       for(int j=i; j<n; j++){
          ergebnis=ergebnis+1;
       } // end for
       for(int k=0; k<n; k++){
          ergebnis=2*ergebnis;
       } //end for
    } // end for
    return ergebnis;
}// end proc

//Annahme: Gehen Sie davon aus, dass a und b quadratische Matrizen
//der Dimension (n,n) sind.
static int[][] maMult (int[][] a, int[][] b){
   int[][] c=new int[a.length][b[0].length];
   for (int i=0; i<a.length; i++){
     for (int j=0; j<b[0].length; j++){
       c[i][j]=0;
       for (int k=0; k<b.length; k++){
          c[i][j]=c[i][j]+(a[i][k]*b[k][j]);
       } // end for
     } // end for
  } // end for
  return c;
}// end proc


        
Bezug
asymptotische Aufwandsabschätz: Formatierung
Status: (Mitteilung) Reaktion unnötig Status 
Datum: 19:56 Di 23.11.2004
Autor: Softwarekoch

Hallo oder Guten Tag oder Guten Morgen oder wie auch immer ;)

Also wenn du den Quelltext besser formatierst, ist er viel einfacher zu lesen.

Danke, Thomas ;)

Bezug
        
Bezug
asymptotische Aufwandsabschätz: Eigentlich nur Zählen
Status: (Antwort) fertig Status 
Datum: 09:43 Sa 27.11.2004
Autor: Softwarekoch

Hallo.
Bei der Aufwandsabschätzung musst du eigentlich nur zählen. Da eine Multiplikation bzw Division mehr Zeit in Anspruch nimmt, wird eine Addition und eine Multiplikation in einer "Punktoperation" zusammengefasst (warum auch immer). Du musst also ermitteln, wie viele Punktoperationen im ungünstigsten Fall ("worst case") durchgeführt werden. Für deinen ersten Algorithmus wären das:

Prozedur unwichtig(int n) {
   for(int i=0; i < n; i++){   //SCHLEIFE 1
       for(int j=i; j<n; j++){   //SCHLEIFE 2
          ergebnis=ergebnis+1;
       } // end for (2)
       for(int k=0; k<n; k++){   //SCHLEIFE 3
          ergebnis=2*ergebnis;
       } //end for (2)
    } // end for (1)
    return ergebnis;
}// end proc

Zur SCHLEIFE 2:
n + (n-1) + (n-2) + ... + (1) =  [mm] \bruch{n(n+1)}{2} [/mm] Durchläufe. Aber nur Additionen

Zur SCHLEIFE 3:
n + n + ... + n =   [mm] n^{2} [/mm] Durchläufe. Hier Multiplikationen.

SCHLEIFE 2 und SCHLEIFE 3 zusammen:
Da es mehr Additionen als Multiplikationen sind, kann die SCHLEIFE 2 außen vorgelassen werden. Es zählt der Aufwand der SCHLEIFE 3. Somit gilt:

Obere Aufwandsabschätzung: [mm] O(n^{2}) [/mm]


Die zweite Abschätzung solltest du selber mal probieren und deine Ansätze posten...


Thomas :)


Bezug
        
Bezug
asymptotische Aufwandsabschätz: Frage (für Interessierte)
Status: (Frage) für Interessierte Status 
Datum: 18:26 Sa 27.11.2004
Autor: mausi

keine ahnung es geht um matrizen hmm ich verstehe jetzt wie du bei der ersten funktion vorgegangen bist aber hier bin ich ratlos es sind ja 3 schleifen is klar und es geht um ein 2dimensionales array hmm aber weiter weiss ich auch nicht,bitte nochmal helfen

Bezug
Ansicht: [ geschachtelt ] | ^ Forum "Algorithmen und Datenstrukturen"  | ^^ Alle Foren  | ^ Forenbaum  | Materialien


^ Seitenanfang ^
www.schulmatheforum.de
[ Startseite | Forum | Wissen | Kurse | Mitglieder | Team | Impressum ]