AGB  ·  Datenschutz  ·  Impressum  







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

hilfe beim verkürzen meines codes

Ein Thema von almanciyabanci · begonnen am 31. Mai 2014 · letzter Beitrag vom 31. Mai 2014
Antwort Antwort
Seite 1 von 2  1 2      
almanciyabanci

Registriert seit: 24. Mai 2014
2 Beiträge
 
#1

hilfe beim verkürzen meines codes

  Alt 31. Mai 2014, 02:36
hallo alle zusammen,

ich habe folgendes ein problem mit der if schleife, der Ablauf funktioniert zwar aber ich möchte den code verkürzen jedoch kriege ich es nicht hin.

Meine beiden variablen : kmneu und tacho sind Double, zu der variable tacho soll ab 15km immer im 10km tack ein 0,1km dazu addiert werden

NUr ein bruch teil meines langen codes..

Code:

if kmneu>= 1005 then
    begin
     tacho:= kmneu + (kmneu / 100 * 10)
    end
   else if kmneu>= 995 then
     begin
      tacho:= kmneu + (1 / 10 * 100)
     end
   else if kmneu>= 985 then
     begin
      tacho:= kmneu+(1 / 10 * 99)
      end
   else if kmneu>= 975 then
     begin
      tacho:= kmneu+ (1 / 10 * 98)
      end
   else if kmneu>= 965 then
     begin
      tacho:= kmneu+ (1 / 10 * 97)
      end
.
.
.
.
.
else if kmneu>= 35 then
     begin
      tacho:= kmneu+ (1 / 10 * 4)
      end
   else if kmneu>= 25 then
     begin
      tacho:= kmneu+ (1 / 10 * 3)
      end
   else if kmneu>= 15 then
     begin
      tacho:= kmneu+ (1 / 10 * 2)
      end
   else begin
      tacho:= kmneu
      end;
  Mit Zitat antworten Zitat
Benutzerbild von himitsu
himitsu

Registriert seit: 11. Okt 2003
Ort: Elbflorenz
43.163 Beiträge
 
Delphi 12 Athens
 
#2

AW: hilfe beim verkürzen meines codes

  Alt 31. Mai 2014, 03:22
Delphi-Quellcode:
if kmneu >= 1005 then
  tacho := kmneu + (kmneu / 100 * 10)
else if kmneu >= 995 then
  tacho := kmneu + (1 / 10 * 100)
else if kmneu >= 985 then
  tacho := kmneu + (1 / 10 * 99)
else if kmneu >= 975 then
  tacho := kmneu + (1 / 10 * 98)
else if kmneu >= 965 then
  tacho := kmneu + (1 / 10 * 97)
...
else if kmneu >= 35 then
  tacho := kmneu + (1 / 10 * 4)
else if kmneu >= 25 then
  tacho := kmneu + (1 / 10 * 3)
else if kmneu >= 15 then
  tacho := kmneu + (1 / 10 * 2)
else
  tacho := kmneu;
Wenn es nur ein Befehl ist, dann kann man sich natürlich das Begin-End sparen.
Und dann gibt es natürlich noch das Case.
Delphi-Quellcode:
case kmneu of
  1005..10014{weiß ich nicht}: tacho := kmneu + (kmneu / 100 * 10);
  995..1004: tacho := kmneu + (1 / 10 * 100);
  985..994: tacho := kmneu + (1 / 10 * 99);
  975..984: tacho := kmneu + (1 / 10 * 98);
  965..974: tacho := kmneu + (1 / 10 * 97);
  ...
  35..44: tacho := kmneu + (1 / 10 * 4);
  25..34: tacho := kmneu + (1 / 10 * 3);
  15..24: tacho := kmneu + (1 / 10 * 2);
  else tacho := kmneu;
end;
Und wie dir auffällt, sind da fortlaufende Zahlen sind, welche man zusammenfassen kann.
Delphi-Quellcode:
case kmneu - 5 of
  1000..1009:
  990..999:
  980..989:
  970..979:
  960..969:
  ...
  30..39:
  20..29:
  10..19:
  else
end;
Delphi-Quellcode:
case (kmneu - 5) div 10 of
  100:
  99:
  98:
  97:
  96:
  ...
  3:
  2:
  1:
  else
end;
Und wenn man weiter sieht, dann kann man die mittlere Reihe auch zusammenfassen.
Ein Blick auf die vorrherrige Reihe gibt auh gleich die mathematische Lösung.
Delphi-Quellcode:
  100: tacho := kmneu + (kmneu / 100 * 10);
  1..99: tacho := kmneu + (1 / 10 * ((kmneu - 5) div 10 + 1));
  else tacho := kmneu;
Und nun lässt man einfach noch die äußeren Klammern weg, welche ja nicht nötig sind und stellt löst die Formeln auf.
Delphi-Quellcode:
  100: tacho := kmneu + kmneu / 10;
  1..99: tacho := kmneu + ((kmneu - 5) div 10 + 1) / 10;
  else tacho := kmneu;
Und das wäre selbst mit IF nichtmal so lang geworden, wenn man nur mal nach redundanten Regelmäßigkeiten sucht,
vorallem wenn die in der Ausgangsfrage alle schon vorgegeben waren.

Eventuell sollte man die Aufgabestellungen nochmal genau lesen und das machen, was darin steht.
ab 15 in 10er-Schritten = (kmneu - 15) div 10

Und meinst du nicht, daß 1000 km/h nicht ein bissl viel sind?
So viele IFs hättest du nicht gebraucht, vorallem da sie ja sowieso unnötig wären, wenn man es als Gleichung löst.

Und wo steht eigentlich was von der Formel bei 1005... kmh?
Garbage Collector ... Delphianer erzeugen keinen Müll, also brauchen sie auch keinen Müllsucher.
my Delphi wish list : BugReports/FeatureRequests

Geändert von himitsu (31. Mai 2014 um 03:28 Uhr)
  Mit Zitat antworten Zitat
Benutzerbild von sx2008
sx2008

Registriert seit: 15. Feb 2008
Ort: Baden-Württemberg
2.332 Beiträge
 
Delphi 2007 Professional
 
#3

AW: hilfe beim verkürzen meines codes

  Alt 31. Mai 2014, 03:32
Delphi-Quellcode:
var
  n : integer;
begin
  n := floor(kmneu + 5.0);
  // falls kmneu = 25.0 dann wäre n = 30

  n := n div 10;

  tacho := kmneu + (0.1 * n);
Da fehlt noch ne Kleinigkeit und zwar die Prüfung ob km >= 1005 ist und die abweichende Berechnung aber das kriegst du sicher selbst hin.
fork me on Github
  Mit Zitat antworten Zitat
Dejan Vu
(Gast)

n/a Beiträge
 
#4

AW: hilfe beim verkürzen meines codes

  Alt 31. Mai 2014, 08:13
Delphi-Quellcode:
  kmneu := kmneu + 0.1* (trunc(min (1005,kmneu)+0.5) div 10 + 1);
...
Genau die gleiche Idee wie sx2008, nur eben in einer Zeile. Es ging ja um die Kürze, nicht um verständlichen Code. .
Und die Deckelung auf 1005 ist auch eingebaut.

trunc(x + 0.5) konvertiert einen Double in einen Integer und kompensiert dabei eventuelle Rundungfehler.
  Mit Zitat antworten Zitat
Benutzerbild von Sir Rufo
Sir Rufo

Registriert seit: 5. Jan 2005
Ort: Stadthagen
9.454 Beiträge
 
Delphi 10 Seattle Enterprise
 
#5

AW: hilfe beim verkürzen meines codes

  Alt 31. Mai 2014, 08:28
BTW if-schleife
Kaum macht man's richtig - schon funktioniert's
Zertifikat: Sir Rufo (Fingerprint: ‎ea 0a 4c 14 0d b6 3a a4 c1 c5 b9 dc 90 9d f0 e9 de 13 da 60)
  Mit Zitat antworten Zitat
Dejan Vu
(Gast)

n/a Beiträge
 
#6

AW: hilfe beim verkürzen meines codes

  Alt 31. Mai 2014, 08:33
Stimmt nicht:
http://python.about.com/od/tutorial1/ss/begpyctrl_4.htm
  Mit Zitat antworten Zitat
Benutzerbild von Sir Rufo
Sir Rufo

Registriert seit: 5. Jan 2005
Ort: Stadthagen
9.454 Beiträge
 
Delphi 10 Seattle Enterprise
 
#7

AW: hilfe beim verkürzen meines codes

  Alt 31. Mai 2014, 08:37
Seit der Bibel wissen wir doch wie böse Schlangen sind
Kaum macht man's richtig - schon funktioniert's
Zertifikat: Sir Rufo (Fingerprint: ‎ea 0a 4c 14 0d b6 3a a4 c1 c5 b9 dc 90 9d f0 e9 de 13 da 60)
  Mit Zitat antworten Zitat
Dejan Vu
(Gast)

n/a Beiträge
 
#8

AW: hilfe beim verkürzen meines codes

  Alt 31. Mai 2014, 09:58
<OT-Klippe>
Es war so ziemlich der einzige Link, der *nicht* gegen die Schlif-Eife (ich darf das Wort nicht aussprechen ) gewettert hat.
</OT-Klippe>
  Mit Zitat antworten Zitat
Perlsau
(Gast)

n/a Beiträge
 
#9

AW: hilfe beim verkürzen meines codes

  Alt 31. Mai 2014, 10:18
Dadurch, daß ein anderer dieselbe fehlerhafte Ausdrucksweise anwendet, wird sie nicht zu einer korrekten Ausdrucksweise. Allerdings könnte man rekursive Programmierung in manchen Fällen mit ein wenig Phantasie durchaus als IF-Schleife bezeichnen, wenn nach THEN oder ELSE die Methode noch einmal aufgerufen wird.
  Mit Zitat antworten Zitat
Dejan Vu
(Gast)

n/a Beiträge
 
#10

AW: hilfe beim verkürzen meines codes

  Alt 31. Mai 2014, 10:40
Dadurch, daß ein anderer dieselbe fehlerhafte Ausdrucksweise anwendet, wird sie nicht zu einer korrekten Ausdrucksweise....
Was meinst Du, ist mit dem gemeint?
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 1 von 2  1 2      


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 06:30 Uhr.
Powered by vBulletin® Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz