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

Delphi Sources



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

Ответ
 
Опции темы Поиск в этой теме Опции просмотра
  #1  
Старый 04.06.2010, 01:44
nblF-nblF* nblF-nblF* вне форума
Прохожий
 
Регистрация: 02.06.2010
Сообщения: 17
Репутация: 10
По умолчанию repeat-until

У меня написана программа с while а мне надо с repeat until... подскажите как сделать?

Код:
unit Unit1;

interface

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

type
  TForm1 = class(TForm)
    StringGrid1: TStringGrid;
    Label1: TLabel;
    LabeledEdit1: TLabeledEdit;
    procedure FormClick(Sender: TObject);
  private
    { Private declarations }
  public
    { Public declarations }
  end;

var
  Form1: TForm1;

implementation

{$R *.dfm}

procedure TForm1.FormClick(Sender: TObject);
const m=3; n=3;
type klop=array[1..m,1..n] of byte;
var x,y:klop;i,j,k:byte;
  begin
i:=1;
while i<=stringgrid1.ColCount do
  begin
j:=1;
while j<=stringgrid1.RowCount do
  begin
k:=strtoint(labelededit1.Text);
x[i,j]:=strtoint(stringgrid1.Cells[i-1,j-1]);
if x[i,j]<0 then y[i,j]:=x[i,j]*k else
y[i,j]:=x[i,j];
label1.Caption:=label1.Caption+#9+floattostr(y[j,i]);
i:=i+1;
end;
j:=j+1;
label1.Caption:=label1.Caption+#13;
end;
end;
end.
Ответить с цитированием
  #2  
Старый 04.06.2010, 07:13
Аватар для march
march march вне форума
Начинающий
 
Регистрация: 04.05.2009
Сообщения: 110
Репутация: 18
По умолчанию

Если в этом алгоритме все работало как надо, то вот так:
Код:
procedure TForm1.FormClick(Sender: TObject);
const m=3; n=3;
type klop=array[1..m,1..n] of byte;
var x,y:klop;i,j,k:byte;
  begin
i:=0;
repeat
j:=0;
j:=j+1;
repeat
i:=i+1;
k:=strtoint(labelededit1.Text);
x[i,j]:=strtoint(stringgrid1.Cells[i-1,j-1]);
if x[i,j]<0 then y[i,j]:=x[i,j]*k else
y[i,j]:=x[i,j];
label1.Caption:=label1.Caption+#9+floattostr(y[j,i]);
until j<=stringgrid1.RowCount;
label1.Caption:=label1.Caption+#13;
until i<=stringgrid1.ColCount;
end;
end.
только мне кажется, что последовательность счетчиков i и j нарушена
__________________
От корректности формулировки поставленной задачи зависят:
качество, скорость и желание её реализации!
Ответить с цитированием
  #3  
Старый 04.06.2010, 07:15
Аватар для dr. F.I.N.
dr. F.I.N. dr. F.I.N. вне форума
I Like it!
 
Регистрация: 12.12.2009
Адрес: Россия, г. Новосибирск
Сообщения: 663
Версия Delphi: D6/D7
Репутация: 26643
По умолчанию

Код:
Задача: Посчитать сумму чисел от 1 до 100
Код:
Решение с помощью While:
...
i := 1;
s := 0;
while i >= 100 do
begin
  s := s + i;
  Inc(i);
end;
...
Код:
Решение с помощью Repeat-Until:
i := 1;
s := 0;
repeat
  s := s + i;
  Inc(i);
until i > 100;
Ответить с цитированием
  #4  
Старый 04.06.2010, 18:56
nblF-nblF* nblF-nblF* вне форума
Прохожий
 
Регистрация: 02.06.2010
Сообщения: 17
Репутация: 10
По умолчанию

Цитата:
Сообщение от march
только мне кажется, что последовательность счетчиков i и j нарушена

а можно поподробнее о том что у меня тут нарушено...а то программа как-то не правильно работает... мне дана матрица 3х3 и если элемент отрицательный, то надо его умножить на заданный коэффициент.
Ответить с цитированием
Ответ


Delphi Sources

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

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

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

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


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


 

Сайт

Форум

FAQ

Соглашения

Прочее

 

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