AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Thema durchsuchen
Ansicht
Themen-Optionen

Betrag auszahlbar?

Ein Thema von Nersgatt · begonnen am 29. Jun 2011 · letzter Beitrag vom 29. Jun 2011
Antwort Antwort
Benutzerbild von Deep-Sea
Deep-Sea

Registriert seit: 17. Jan 2007
907 Beiträge
 
Delphi XE2 Professional
 
#1

AW: Betrag auszahlbar?

  Alt 29. Jun 2011, 09:10
Es könnte klappen, wenn man nicht einfach die größtmögliche Banknote nimmt, sondern erst mal die Banknote die mit dem auszuzahlenden Betrag den größten gemeinsamen Teiler hat
Reine Theorie die mir spontan so früh am morgen *gähn* einfiel
Chris
Die Erfahrung ist ein strenger Schulmeister: Sie prüft uns, bevor sie uns lehrt.
  Mit Zitat antworten Zitat
Satty67

Registriert seit: 24. Feb 2007
Ort: Baden
1.566 Beiträge
 
Delphi 2007 Professional
 
#2

AW: Betrag auszahlbar?

  Alt 29. Jun 2011, 09:44
Es kann auch passieren, das nur 2x 20 in der Kasse ist und somit 60 auch nicht mit 20er auszahlbar ist?

1) größten Schein aus der Kasse auswählen

2) (Rest)Betrag durch Schein teilen, bei Ergebnis:

= 1 : fertig, passt
> 1 : Schein von Betrag abziehen/aus Liste nehmen, mit Restmenge bei 1) beginnen
< 1 : Kleinerer Schein auswählbar, bei 2) weiter. Kein kleinerer Schein mehr da -> geht nicht.

Geändert von Satty67 (29. Jun 2011 um 09:47 Uhr)
  Mit Zitat antworten Zitat
Benutzerbild von Nersgatt
Nersgatt

Registriert seit: 12. Sep 2008
Ort: Emlichheim
693 Beiträge
 
Delphi 10.1 Berlin Professional
 
#3

AW: Betrag auszahlbar?

  Alt 29. Jun 2011, 09:53
Es kann auch passieren, das nur 2x 20 in der Kasse ist und somit 60 auch nicht mit 20er auszahlbar ist?
Nein, es wird angenommen, dass immer unendlich viele Scheine in der Kasse sind (leider nur eine Annahme ).

Ich hab jetzt hoffentlich eine Lösung. Das ganze hab ich rekursiv gelöst. Bei jedem Funktionsaufruf wird geprüft, ob der (Rest-) Betrag durch eine der Noten teilbar ist. Wenn ja: fertig.

Bisher hab ich kein Beispiel gefunden, wo es nicht funktioniert. Vielleicht möchte ja jemand versuchen, ein Beispiel zu finden, wo es fehlschlägt.

Delphi-Quellcode:
unit UVorschuss;

interface

uses
  Generics.Collections;

type
  TGeldstueckliste = TList<Currency>;
  TVorschuss = class(TObject)
  private
    FGeldstueckliste: TGeldstueckliste;
    Function GroessterBetrag(ABetrag : Currency) : Currency;
  protected

  public
    constructor Create;
    destructor Destroy; override;
    property Geldstueckliste : TGeldstueckliste read FGeldstueckliste;
    Function IsBetragAuszahlbar(ABetrag : Currency) : Boolean;
  end;

implementation


{ TVorschuss }

constructor TVorschuss.Create;
begin
  inherited;

  FGeldstueckliste := TGeldstueckliste.Create;
end;

destructor TVorschuss.Destroy;
begin

  FGeldstueckliste.Free;

  inherited;
end;

function TVorschuss.GroessterBetrag(ABetrag: Currency): Currency;
var
  Geldstueck : Double;
begin

  result := 0;
  for Geldstueck in FGeldstueckliste do
  begin
    if (Geldstueck <= ABetrag) and (Geldstueck > Result) then
      result := Geldstueck;
  end;

end;

function TVorschuss.IsBetragAuszahlbar(ABetrag: Currency): Boolean;
var
  sub : Double;
  NeuerBetrag : Double;
  i : integer;
  intBetrag : integer;
begin

  result := False;
  i := 0;
  intBetrag := trunc(ABetrag * 100);
  while (i <= FGeldstueckliste.Count - 1) and not result do
  begin
    result := (intBetrag mod trunc(FGeldstueckliste.Items[i] * 100)) = 0;
    inc(i);
  end;

  if not Result then
  begin
    sub := GroessterBetrag(ABetrag);
    if sub > 0 then
    begin
      NeuerBetrag := ABetrag - sub;
      if NeuerBetrag = 0 then
         result := True
      else
        result := IsBetragAuszahlbar(NeuerBetrag);
    end
    else
      result := false;
  end;
end;

end.
Jens
  Mit Zitat antworten Zitat
Antwort Antwort


Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 04:00 Uhr.
Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024-2025 by Thomas Breitkreuz