Форум по Delphi программированию

Delphi Sources



Вернуться   Форум по Delphi программированию > Все о Delphi > [ "Начинающим" ]
Ник
Пароль
Регистрация <<         Правила форума         >> FAQ Пользователи Календарь Поиск Сообщения за сегодня Все разделы прочитаны

Ответ
 
Опции темы Поиск в этой теме Опции просмотра
  #1  
Старый 21.06.2012, 17:36
Radichek Radichek вне форума
Прохожий
 
Регистрация: 21.06.2012
Сообщения: 5
Репутация: 10
По умолчанию Сортировка в дельфи.

Ситуация следующая. Нужно дописать программу. Первый столбец при нажатии первой кнопки должен рандомно заполняться числами. При нажатии второй кнопки, второй столбец должен упорядочить эти числа в порядке возрастания. Первое получилось. но при нажатии второй кнопки, он ставит все числа так же, как в первом столбце. Пожалуйста подскажите, что дописать нужно.

Код:
unit GLAV_FM;

interface

uses
  Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms,
  Dialogs, StdCtrls, Grids;

type
  TFM_GLAV = class(TForm)
    TABL: TStringGrid;
    POLE_N: TEdit;
    KN_ZAP: TButton;
    KN_SORT: TButton;
    procedure KN_ZAPClick(Sender: TObject);
    procedure FormCreate(Sender: TObject);
    procedure KN_SORTClick(Sender: TObject);
  private
    { Private declarations }
  public
    { Public declarations }
  end;

var
  FM_GLAV: TFM_GLAV;

implementation

{$R *.dfm}
CONST
    MAX_N = 300
;
TYPE
   T_M = ARRAY [ 1 .. MAX_N ] OF WORD
;
VAR
   N : WORD
;


PROCEDURE PP_SORT ( K: WORD ; VAR M : T_M );
BEGIN
 // сделать
END
;

procedure TFM_GLAV.FormCreate(Sender: TObject);
VAR
   I: WORD
;
begin

   N := STRTOINT ( POLE_N.Text )
   ;
   IF  N > MAX_N THEN
   BEGIN
      N := MAX_N;
      POLE_N.Text := INTTOSTR ( N )
   END
   ;
   TABL.RowCount := N + 1
   ;
   FOR I := 1 TO N DO
   BEGIN
      TABL.Cells [ 0 , I ] := INTTOSTR ( I )
      ;
      TABL.Cells [ 1 , I ] := INTTOSTR ( ROUND ( 1 + 498 * RANDOM ) )
   END

end;

procedure TFM_GLAV.KN_SORTClick(Sender: TObject);
VAR
   I: WORD
   ;
   CHISLA : T_M
;
begin
   FOR I := 1 TO N DO
   BEGIN
      CHISLA [ I ] := STRTOINT ( TABL.Cells [ 1 , I ] )
      ;
      PP_SORT ( N, CHISLA )
      ;
      TABL.Cells [ 2 , I ] := INTTOSTR ( CHISLA [ I ] )
   END
end;

procedure TFM_GLAV.KN_ZAPClick(Sender: TObject);
VAR
   I: WORD
;
begin

   N := STRTOINT ( POLE_N.Text )
   ;
   IF  N > MAX_N THEN
   BEGIN
      N := MAX_N;
      POLE_N.Text := INTTOSTR ( N )
   END
   ;
   TABL.RowCount := N + 1
   ;
   FOR I := 1 TO N DO
   BEGIN
      TABL.Cells [ 0 , I ] := INTTOSTR ( I )
      ;
      TABL.Cells [ 1 , I ] := INTTOSTR ( ROUND ( 1 + 498 * RANDOM ) )
   END
end;

end.

Последний раз редактировалось Radichek, 21.06.2012 в 17:56.
Ответить с цитированием
  #2  
Старый 21.06.2012, 18:21
Аватар для ined
ined ined вне форума
Начинающий
 
Регистрация: 16.11.2008
Адрес: Российская Федерация!! :)
Сообщения: 165
Версия Delphi: Delphi 2010
Репутация: 1272
По умолчанию

Строки 79 - 86. Надо заменить на:
Код:
 FOR I := 1 TO N DO CHISLA [ I ] := STRTOINT ( TABL.Cells [ 1 , I ] );// Тут загружаем список
PP_SORT ( N, CHISLA ); // Тут отправляем на сортировку 
FOR I := 1 TO N DO TABL.Cells [ 2 , I ] := INTTOSTR ( CHISLA [ I ] ); // Тут выводим что получилось 
Дальше думай сам как тебе удобней сортировать, в процедуре PP_SORT))
Ответить с цитированием
  #3  
Старый 21.06.2012, 18:31
Radichek Radichek вне форума
Прохожий
 
Регистрация: 21.06.2012
Сообщения: 5
Репутация: 10
По умолчанию

Ребят, стыдно признаться, но реально не шарю, помогите пожалуйста. От этого зависит завтрашний экзамен.
Ответить с цитированием
  #4  
Старый 21.06.2012, 18:42
Аватар для ined
ined ined вне форума
Начинающий
 
Регистрация: 16.11.2008
Адрес: Российская Федерация!! :)
Сообщения: 165
Версия Delphi: Delphi 2010
Репутация: 1272
По умолчанию

Цитата:
Сообщение от Radichek
Ребят, стыдно признаться, но реально не шарю, помогите пожалуйста. От этого зависит завтрашний экзамен.
Я думаю, что тебе надо самому разобраться, что бы в будущем ШАРИТЬ)) мог!!
Ответить с цитированием
  #5  
Старый 21.06.2012, 18:44
Radichek Radichek вне форума
Прохожий
 
Регистрация: 21.06.2012
Сообщения: 5
Репутация: 10
По умолчанию

В будущем естественно. Но завтра экзамен, а его нужно сдать) Помогите)
Ответить с цитированием
  #6  
Старый 21.06.2012, 19:32
Radichek Radichek вне форума
Прохожий
 
Регистрация: 21.06.2012
Сообщения: 5
Репутация: 10
По умолчанию

Вот исходник. Тут все, до того, как я начал изменять.
Вложения
Тип файла: rar TABL-SORT.rar (199.1 Кбайт, 2 просмотров)
Ответить с цитированием
  #7  
Старый 21.06.2012, 19:45
lmikle lmikle вне форума
Модератор
 
Регистрация: 17.04.2008
Сообщения: 8,093
Версия Delphi: 7, XE3, 10.2
Репутация: 49089
По умолчанию

А че, простейшие сортировки не проходили. Классический пузырек, например? Вообще, рекомендую все делать в массиве, а в StringGrid только выводить результаты.

Вот сортировка:
Код:
procedure SortArray(var A : Array Of Integer);
var
  I, J, Swp : Integer,
begin
  For I := Low(A) To High(A)-1 Do
    For J := I + 1 To High(A) Do
      If A[i]>A[J] Then
        Begin
          Swp := A[i];
          A[i] := A[J];
          A[J] := Swp;
        End;
end;
Ответить с цитированием
  #8  
Старый 21.06.2012, 19:59
Аватар для ined
ined ined вне форума
Начинающий
 
Регистрация: 16.11.2008
Адрес: Российская Федерация!! :)
Сообщения: 165
Версия Delphi: Delphi 2010
Репутация: 1272
По умолчанию

Я вот так сделал
Код:
unit GLAV_FM;

interface

uses
  Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms,
  Dialogs, StdCtrls, Grids;

type
  TFM_GLAV = class(TForm)
    TABL: TStringGrid;
    POLE_N: TEdit;
    KN_ZAP: TButton;
    KN_SORT: TButton;
    procedure KN_ZAPClick(Sender: TObject);
    procedure FormCreate(Sender: TObject);
    procedure KN_SORTClick(Sender: TObject);
  private
    { Private declarations }
  public
    { Public declarations }
  end;

var
  FM_GLAV: TFM_GLAV;

implementation

{$R *.dfm}
CONST
    MAX_N = 300
;
TYPE
   T_M = ARRAY [ 1 .. MAX_N ] OF WORD
;
VAR
   N : WORD
;


PROCEDURE PP_SORT ( K: WORD ; VAR M : T_M );
 procedure ma(var a,b:word);
  var t:word;
  begin
   if (a>b) then
     begin
       t:=a;
       a:=b;
       b:=t;
     end;
  end;
var i,j:integer; AA,BB:word;
BEGIN
 for i := 1 to k - 1 do
  for j := 1 to k - 1 do
   begin
    AA:=M[j];
    BB:=M[j+1];
    ma(AA,BB);
    M[j]:=AA;
    M[j+1]:=BB;
   end;
 // сделать
END
;

procedure TFM_GLAV.FormCreate(Sender: TObject);
VAR
   I: WORD
;
begin

   N := STRTOINT ( POLE_N.Text )
   ;
   IF  N > MAX_N THEN
   BEGIN
      N := MAX_N;
      POLE_N.Text := INTTOSTR ( N )
   END
   ;
   TABL.RowCount := N + 1
   ;
   FOR I := 1 TO N DO
   BEGIN
      TABL.Cells [ 0 , I ] := INTTOSTR ( I )
      ;
      TABL.Cells [ 1 , I ] := INTTOSTR ( ROUND ( 1 + 498 * RANDOM ) )
   END

end;

procedure TFM_GLAV.KN_SORTClick(Sender: TObject);
VAR
   I: WORD
   ;
   CHISLA : T_M
;
begin
   FOR I := 1 TO N DO   CHISLA [ I ] := STRTOINT ( TABL.Cells [ 1 , I ] ) ;

   PP_SORT ( N, CHISLA );

   FOR I := 1 TO N DO   TABL.Cells [ 2 , I ] := INTTOSTR ( CHISLA [ I ] )

end;

procedure TFM_GLAV.KN_ZAPClick(Sender: TObject);
VAR
   I: WORD
;
begin

   N := STRTOINT ( POLE_N.Text )
   ;
   IF  N > MAX_N THEN
   BEGIN
      N := MAX_N;
      POLE_N.Text := INTTOSTR ( N )
   END
   ;
   TABL.RowCount := N + 1
   ;
   FOR I := 1 TO N DO
   BEGIN
      TABL.Cells [ 0 , I ] := INTTOSTR ( I )
      ;
      TABL.Cells [ 1 , I ] := INTTOSTR ( ROUND ( 1 + 498 * RANDOM ) )
   END
end;

end.
У меня всё работает.
Ответить с цитированием
  #9  
Старый 21.06.2012, 20:09
Аватар для ined
ined ined вне форума
Начинающий
 
Регистрация: 16.11.2008
Адрес: Российская Федерация!! :)
Сообщения: 165
Версия Delphi: Delphi 2010
Репутация: 1272
По умолчанию

Я хотел как то разнообразить ))))))))
Ответить с цитированием
  #10  
Старый 22.06.2012, 00:23
Radichek Radichek вне форума
Прохожий
 
Регистрация: 21.06.2012
Сообщения: 5
Репутация: 10
По умолчанию

Ребята, помогите, пожалуйста. Все сделал как описано выше, почему то результат не меняется.
Ответить с цитированием
  #11  
Старый 22.06.2012, 08:51
Аватар для ined
ined ined вне форума
Начинающий
 
Регистрация: 16.11.2008
Адрес: Российская Федерация!! :)
Сообщения: 165
Версия Delphi: Delphi 2010
Репутация: 1272
По умолчанию

Цитата:
Сообщение от Radichek
Ребята, помогите, пожалуйста. Все сделал как описано выше, почему то результат не меняется.
TABL-SORT.zip Надеюсь ты всё понял, о выше сказанном!!!!
__________________
11011111 INED Home code
VK
Ответить с цитированием
Ответ


Delphi Sources

Опции темы Поиск в этой теме
Поиск в этой теме:

Расширенный поиск
Опции просмотра

Ваши права в разделе
Вы не можете создавать темы
Вы не можете отвечать на сообщения
Вы не можете прикреплять файлы
Вы не можете редактировать сообщения

BB-коды Вкл.
Смайлы Вкл.
[IMG] код Вкл.
HTML код Выкл.
Быстрый переход


Часовой пояс GMT +3, время: 12:13.


 

Сайт

Форум

FAQ

Соглашения

Прочее

 

Copyright © Форум "Delphi Sources" by BrokenByte Software, 2004-2025