1 Euro Rätsel



  • Hallo Bashar: Du würdest also die Funktion mit 100 Cent aufrufen und dann 1 Cent abziehen und dann rekursiv aufrufen. Nachdem die Rekursion beendet ist 2 Cent abziehen und wieder rekursieren... so ganz habe ich es nicht verstanden. Aber so wie ich es oben beschrieben habe wäre es etwas anderes wenn ich zuerst 98 1Cent Stücke auszahle und dann ein 2Cent Stück auszahle oder andersrum. Da der Radiomoderator natürlich kein Mathematiker war hat er dazu nichts gesagt. 😃 Zählt aber vermutlich als eine Möglichkeit.

    @Volkard: Du meinst weil man auch 0 1Cent Stücke auszahlen kann. Hast Recht;-)



  • Euristiker schrieb:

    Hallo Bashar: Du würdest also die Funktion mit 100 Cent aufrufen und dann 1 Cent abziehen und dann rekursiv aufrufen. Nachdem die Rekursion beendet ist 2 Cent abziehen und wieder rekursieren... so ganz habe ich es nicht verstanden.

    Ja, in der Basisversion schon. Man könnte aber auch hier als Optimierung feststellen, dass es für n Cent in Einern aufgeteilt nur eine Zerlegung gibt und einfach 1 zurückgeben. Das ändert aber am Ergebnis nichts, und ich wollte es erstmal einfach halten.

    Aber so wie ich es oben beschrieben habe wäre es etwas anderes wenn ich zuerst 98 1Cent Stücke auszahle und dann ein 2Cent Stück auszahle oder andersrum. Da der Radiomoderator natürlich kein Mathematiker war hat er dazu nichts gesagt. 😃 Zählt aber vermutlich als eine Möglichkeit.

    Ich versteh nicht ganz, worauf du hinauswillst. In meiner Lösung spielt Reihenfolge keine Rolle, was mir auch als das sinnvollste erscheint.

    Edit:
    Man sollte vielleicht Zwischenergebnisse abspeichern, damit man nicht 10000mal wieder berechnen muss, wie man 20 in 5ern, 2ern und 1ern zerlegt.



  • Bashar schrieb:

    Edit:
    Man sollte vielleicht Zwischenergebnisse abspeichern, damit man nicht 10000mal wieder berechnen muss, wie man 20 in 5ern, 2ern und 1ern zerlegt.

    jo.

    und vielleicht be 1-cent anfangen.
    für 1-cent alle 101 möglichkeiten.
    von denen nur die mit 2-cent dazu, wenn die summe durch 5 teilbar istm, weil nur das mit den größeren aufgefüllt werden kann.
    mit 5-ern nur die nehmen, die in summe duch 10 teilbar sind.
    evtl wird das was, ka.#





  • was ist denn die lösung?



  • Müßt Euch bis morgen gedulden. War aber sowas wie 4623. Kann den Code auch mal posten...

    @Bashar: Ich wollte auf die Reichenfolge hinaus. Hatte Deine Lösung zuerst nicht verstanden.



  • @Surftipp: Die Aufgabe allgemein zu lösen ist dann wohl doch ein bischen härter.



  • jep das gheht ueber ne rekursion

    mein prof hat mal ne * aufageb gestellt und zwar

    wieviele kombinationen gibt es einen betrag mit 2,1,5 cent stuecken zu bezahlen

    war nur leider nicht anwesend als er die leosung vorgestellt hatte geschweige denn sie gefunden zu haben



  • Die unoptimierte Basisversion:

    #include <iostream>
    
    int muenzwerte[] = { 1, 2, 5, 10, 20, 50, 100 };
    int zerlegungen(int betrag, int max_muenze)
    {
       if (betrag == 0)
          return 1;
       else if (betrag < 0)
          return 0;
       else
       {
          int zaehler = 0, i = max_muenze;
          while (true) 
          {
             zaehler += zerlegungen(betrag - muenzwerte[i], i);
             if (i == 0) 
                break;
             --i;
          } 
          return zaehler;
       }
    }
    
    int main() {
       std::cout << "100 Cent können auf " << zerlegungen(100, 6) 
                 << " Arten zerlegt werden." << std::endl;
    }
    

    Gewinnt keinen Schönheitspreis, hat aber nicht lange gedauert und läuft im Millisekundenbereich.



  • int main(int argc, char* argv[]) {
    	int c1, c2, c5, c10, c20, c50, ergebnis;
    	c1=0; c2=2; c5=0; c10=0; c20=0; c50=0; ergebnis=0;
    
    	/* Es werden ALLE möglichen Kombinationen durchgegangen. */ 
    	do {
    
    		c1++;
    		if (c1>100) {
    			c1=0;
    			c2++;
    			if (c2>50) {
    				c2=0;
    				c5++;
    				if (c5>20) {
    					c5=0;
    					c10++;
    					if (c10>10) {
    						c10=0;
    						c20++;
    						if (c20>5) {
    							c20=0;
    							c50++;
    						}
    					}
    				}
    			}	
    		}
    
    		if (c1 + 2*c2 + 5*c5 + 10*c10 + 20*c20 + 50*c50 == 100) ergebnis++;
    	} while (c50<2);
    
    	ergebnis++; // + eine 100 Cent Stück Kombination.
    
    	printf("%d", ergebnis);
    	return 0;
    }
    

    Es sollte eigentlich 4563 rauskommen. Kommt aber nur 4561 raus 😞



  • Hi,

    die Frage war sehr interessant und interessante Fragen werden
    hier
    immer sehr freundlich und kompetent bearbeitet. Insbesondere auch
    diese (siehe insb.[18]).

    Jockel


Anmelden zum Antworten