www.vorhilfe.de
Vorhilfe

Kostenlose Kommunikationsplattform für gegenseitige Hilfestellungen.
Hallo Gast!einloggen | registrieren ]
Startseite · Forum · Wissen · Kurse · Mitglieder · Team · Impressum
Forenbaum
^ Forenbaum
Status Englisch
  Status Grammatik
  Status Lektüre
  Status Korrekturlesen
  Status Übersetzung
  Status Sonstiges (Englisch)

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
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.englischraum.de
[ Startseite | Forum | Wissen | Kurse | Mitglieder | Team | Impressum ]