AGB  ·  Datenschutz  ·  Impressum  







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

ReverseString

Ein Thema von Landogar-Garuno · begonnen am 24. Feb 2011 · letzter Beitrag vom 24. Feb 2011
Antwort Antwort
Landogar-Garuno

Registriert seit: 22. Feb 2008
36 Beiträge
 
#1

ReverseString

  Alt 24. Feb 2011, 05:10
Hallo alle zusammen

bekomme es einfach nicht hin


input 78563412
bekomme es nur so hin
output 21436587


brauche aber
input 78563412
output 12345678

jemand ne idee !!
  Mit Zitat antworten Zitat
Benutzerbild von MGC
MGC

Registriert seit: 15. Mai 2008
Ort: Helsa
106 Beiträge
 
Turbo Delphi für Win32
 
#2

AW: ReverseString

  Alt 24. Feb 2011, 05:46
Hallo,

da ein String im Prinzip ähnlich einem Zeichen-Array ist lassen sich wunderbar Sortier-Algorithmen darauf anwenden.

Sieh mal hier nach:
http://www.delphipraxis.net/281-tuto...hmen-i-ii.html
http://www.delphipraxis.net/5603-3-v...verfahren.html
Marc
  Mit Zitat antworten Zitat
-187-

Registriert seit: 24. Sep 2005
483 Beiträge
 
Delphi 2010 Architect
 
#3

AW: ReverseString

  Alt 24. Feb 2011, 06:37
Habe folgende Funktion mal irgendwo gefunden und in meine Bib mit aufgenommen. Ist recht simple aber effektiv...Aaaaber es gibt noch eine schönere Variante die hab ich jedoch vergessen...wird aber irgendwo im Forum besprochen.

Delphi-Quellcode:
Function String_Reverse(S : String): String;
Var
   i : Integer;
Begin
   Result := '';
   For i := Length(S) DownTo 1 Do
   Begin
     Result := Result + Copy(S,i,1) ;
   End;
End;
  Mit Zitat antworten Zitat
Benutzerbild von himitsu
himitsu

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

AW: ReverseString

  Alt 24. Feb 2011, 08:22
Delphi-Quellcode:
function ReverseString2(S: String): String;
var
  i, i2: Integer;
begin
  Result := S;
  i2 := Length(S) div 2;
  for i := 1 to i2 do begin
    Result[i * 2 - 1] := S[(i2 - i + 1) * 2 - 1];
    Result[i * 2] := S[(i2 - i + 1) * 2];
  end;
end;
// oder
begin
  Result := S;
  i2 := Length(S) div 2;
  for i := 0 to i2 - 1 do begin
    Result[i * 2 + 1] := S[(i2 - i) * 2 - 1];
    Result[i * 2 + 2] := S[(i2 - i) * 2];
  end;
end;
Einfach ein bissl Mathematik und die passenden Zeichenoperationen.
$2B or not $2B

Geändert von himitsu (24. Feb 2011 um 08:26 Uhr)
  Mit Zitat antworten Zitat
Benutzerbild von ChrisE
ChrisE

Registriert seit: 15. Feb 2006
Ort: Hechingen
504 Beiträge
 
Delphi 10.2 Tokyo Professional
 
#5

AW: ReverseString

  Alt 24. Feb 2011, 08:25
Hallo,

war die Frage nicht genau die, dass er das verhalten von Delphi-Referenz durchsuchenReverseString eben nicht will, sondern eigentlich den String Sortiert haben will?
input 78563412
bekomme es nur so hin
output 21436587

brauche aber
input 78563412
output 12345678
Gruß, Chris
Christian E.
Es gibt 10 Arten von Menschen, die die Binär lesen können und die die es nicht können

Delphi programming rules
  Mit Zitat antworten Zitat
Benutzerbild von himitsu
himitsu

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

AW: ReverseString

  Alt 24. Feb 2011, 08:35
Das ist hier die Frage ... Möchte er eine Sortierung oder sind die Zahlen nur als wertunabhängiges Beispiel zu sehn?

> sortieren
> ReversteString + sowas wie LittleEndian/BigEndian
$2B or not $2B
  Mit Zitat antworten Zitat
Benutzerbild von mleyen
mleyen

Registriert seit: 10. Aug 2007
609 Beiträge
 
FreePascal / Lazarus
 
#7

AW: ReverseString

  Alt 24. Feb 2011, 08:37
Delphi-Quellcode:
  procedure QSortStr(var AStr: string);
  var
    tmp: Char;

    procedure QSortAll(const LoIndex, HiIndex: Integer);
    var
      Lo, Hi: Integer;
      Pivot: Integer;
    begin
      Lo := LoIndex;
      Hi := HiIndex;
      Pivot := StrToInt(AStr[(Lo + Hi) div 2]);

      repeat
        while StrToInt(AStr[Lo]) < Pivot do
          Inc(Lo);
        while StrToInt(AStr[Hi]) > Pivot do
          Dec(Hi);
        if Lo <= Hi then
        begin
          if Lo < Hi then
            if AStr[Lo] <> AStr[Hi] then
            begin
              tmp := AStr[Lo];
              AStr[Lo] := AStr[Hi];
              AStr[Hi] := tmp;
            end;
          Inc(Lo);
          Dec(Hi);
        end;
      until Lo > Hi;

      if LoIndex < Hi then
        QSortAll(LoIndex, Hi);
      if Lo < HiIndex then
        QSortAll(Lo, HiIndex);
    end;

  begin
    if Length(AStr) > 0 then
      QSortAll(1, Length(AStr));
  end;

  function getQSortedStr(const AStr: string): string;
  begin
    Result := AStr;
    QSortStr(Result);
  end;

Geändert von mleyen (24. Feb 2011 um 09:23 Uhr)
  Mit Zitat antworten Zitat
Benutzerbild von Uwe Raabe
Uwe Raabe
Online

Registriert seit: 20. Jan 2006
Ort: Lübbecke
11.530 Beiträge
 
Delphi 12 Athens
 
#8

AW: ReverseString

  Alt 24. Feb 2011, 09:01
brauche aber
input 78563412
output 12345678
Leider ist hier noch keine Regel erkennbar. Zum Einen kann es sein, daß du die einzelnen Ziffern sortiert haben willst, zum Anderen kann es aber auch sein, daß du die Reihenfolge umdrehen willst, dabei aber immer Gruppen von zwei Ziffern bildest, die so bleiben sollen:

78 56 34 12
12 34 56 78

Also, was soll es tun?
Uwe Raabe
Certified Delphi Master Developer
Embarcadero MVP
Blog: The Art of Delphi Programming
  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 23:04 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 by Thomas Breitkreuz