일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | 5 | 6 | 7 |
8 | 9 | 10 | 11 | 12 | 13 | 14 |
15 | 16 | 17 | 18 | 19 | 20 | 21 |
22 | 23 | 24 | 25 | 26 | 27 | 28 |
29 | 30 | 31 |
- 소니
- 데이터베이스
- MFC
- 델파이
- Delphi
- c#
- 시리얼 통신
- PostgreSQL
- dll
- Visual Basic
- SDK
- 입문
- 문자열
- 예제
- WIN32 SDK
- winsock
- SQL
- Firebird
- xml
- 기초
- 파라미터
- MySQL
- 셋업
- VB.NET
- vb
- Visual Studio 2005
- 파이어버드
- 설치
- 초보
- 인스톨
- Today
- Total
프로그래밍 노트
[델파이]문자열 배열의 정렬 본문
문자열 배열의 정렬 소스
var
arSort: array[1..12] of string
= ('d','e','f','a','b','c','h','a','i','j','k','l');
procedure TForm1.Button1Click(Sender: TObject);
var
sLst: string;
iIdx: Integer;
bSortingEnd: Boolean;
bChange: boolean;
i : integer;
begin
Listbox1.Clear;
repeat
bSortingEnd := False;
iIdx := 1;
repeat
bChange := false;
if checkbox1.Checked then
begin // 내림차순(c, b, a ...)
if CompareStr(arSort[iIdx+1], arSort[iIdx]) > 0 then bChange := true
end
else
begin // 오름차순(a, b, c ...)
if CompareStr(arSort[iIdx], arSort[iIdx+1]) > 0 then bChange := true;
end;
if bChange then
begin
sLst := arSort[iIdx];
arSort[iIdx] := arSort[iIdx+1];
arSort[iIdx+1] := sLst;
bSortingEnd := True;
end;
Inc(iIdx);
until(iIdx > High(arSort) - 1);
until(bSortingEnd = False);
for i := Low(arSort) to High(arSort) do
begin
Listbox1.Items.Add(arSort[i]);
end;
end;