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

Delphi Sources



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

Ответ
 
Опции темы Поиск в этой теме Опции просмотра
  #1  
Старый 06.03.2008, 16:34
Lukas Lukas вне форума
Прохожий
 
Регистрация: 06.03.2008
Сообщения: 5
Репутация: 10
Радость Помогите разобраться!!!

Народ помогите разобраться с программой которая создает массив случайных целых чисел, подсчитывает их среднее арифметическое, а также определяет и выводит на экран минимальное и максимальное из этих чисел.
Кому не трудно посмотрите plizzz и скажите, что я сделал не так! Прога не может подсчитать мин. макс. числа!

Код:
procedure TfmExample.BEnterClick(Sender: TObject);
const
N = 1000;
MAX_VALUE = 100+1;
var
   m: array [1..N] of Integer;
   i: Integer;
   max,min: Integer;
   sum: Real;
begin
for i:=1 to N do
m[i]:= Random (MAX_VALUE);
sum := m[1];
max := m[1];
min := m[1];
for i:= 2 to N do
begin
 sum :=sum+m[i];
if m[i]<min then min:= m[i]
else if m[i]>max then max:= m[i]
end;
 mmOutput.Lines.Add('Минимальное значение данного массива равно '+inttostr(min));
 mmOutput.Lines.Add('Среднее арифметическое число данного массива равно '+floattostr(sum/N));
 mmOutput.Lines.Add('Максимальное значение данного массива равно '+inttostr(max));
end;

Последний раз редактировалось Lukas, 06.03.2008 в 16:49.
Ответить с цитированием
  #2  
Старый 07.03.2008, 07:01
Rosenkrantz Rosenkrantz вне форума
Активный
 
Регистрация: 04.12.2007
Адрес: Москва
Сообщения: 234
Версия Delphi: Delphi 7
Репутация: 40
По умолчанию

На мой взгляд все правильно. А что вас не устраивает в результатах работы программы?
Ответить с цитированием
  #3  
Старый 07.03.2008, 10:17
Аватар для KOOL
KOOL KOOL вне форума
Активный
 
Регистрация: 06.01.2008
Адрес: Рязань
Сообщения: 306
Версия Delphi: 2009
Репутация: 6150
По умолчанию

Все действительно правильно, но вычисление min и max я бы выделил в отдельную процедуру:
Код:
function FindMin(Arr : array of integer) : integer; //возвращает само значение, но не индекс
var i : integer;
begin
  Result := Arr[0];
  for i := 1 to Length(Arr)-1 do
    if ( Arr[i] < Result ) then
      Result := Arr[i];
end;

function FindMax(Arr : array of integer) : integer;
var i : integer;
begin
  Result := Arr[0];
  for i := 1 to Length(Arr)-1 do
    if ( Arr[i] > Result ) then
      Result := Arr[i];
end;

mmOutput.Lines.Add('Минимальное значение данного массива равно '+inttostr(FindMin(m)));
mmOutput.Lines.Add('Максимальное значение данного массива равно '+inttostr(FindMax(m)));
Это не обязательно..просто пригодится может где-нибуть еще.
Дело в том, что при N=1000 шанс, что в массиве будет 0 и 100 равен 1. Уменьши N до..скажем..10 или MAX_VALUE до..5001 и результаты тебя порадуют

Последний раз редактировалось KOOL, 07.03.2008 в 10:44.
Ответить с цитированием
  #4  
Старый 07.03.2008, 10:20
Аватар для Thrasher
Thrasher Thrasher вне форума
Illuminati
 
Регистрация: 06.03.2008
Адрес: Крым, г. Симферополь
Сообщения: 348
Репутация: 8808
Восклицание

Ошибка вот в чем - сортировать нужно ВЕСЬ массив, а не со 2-го его элемента.

Вообще-то это должно выглядеть так: (я заккоментировал на мой взгляд неправильные конструкции и написал свои).

Код:
procedure TfmExample.BEnterClick(Sender: TObject);
const
N = 1000;
MAX_VALUE = 100+1;
var
   m: array [1..N] of Integer;
   i: Integer;
   max,min: Integer;
   sum: Real;
begin
for i:=1 to N do
m[i]:= Random (MAX_VALUE);
sum:=0;//!!!sum := m[1];
max := m[1];
min := m[1];
for i:= 1//!!!2 to N do
begin
 sum :=sum+m[i];
if m[i]<min then min:= m[i]
else if m[i]>max then max:= m[i]
end;
 mmOutput.Lines.Add('Минимальное значение данного массива равно '+inttostr(min));
 mmOutput.Lines.Add('Среднее арифметическое число данного массива равно '+floattostr(sum/N));
 mmOutput.Lines.Add('Максимальное значение данного массива равно '+inttostr(max));
end;
__________________
Хорошо написанная программа не требует документации
ICQ 9-184-668.
Ответить с цитированием
  #5  
Старый 07.03.2008, 10:49
Аватар для KOOL
KOOL KOOL вне форума
Активный
 
Регистрация: 06.01.2008
Адрес: Рязань
Сообщения: 306
Версия Delphi: 2009
Репутация: 6150
По умолчанию

2Thrasher:
Ошибки тут нет. Если ты не заметил, нумерация массива идет с 1
Ответить с цитированием
  #6  
Старый 07.03.2008, 12:23
Lukas Lukas вне форума
Прохожий
 
Регистрация: 06.03.2008
Сообщения: 5
Репутация: 10
По умолчанию

Все равно не хочет работать, ни как не получается!
Ответить с цитированием
  #7  
Старый 07.03.2008, 12:32
AlexSku AlexSku вне форума
Специалист
 
Регистрация: 07.05.2007
Адрес: Москва
Сообщения: 884
Репутация: 21699
По умолчанию

С помощью модуля Math можно не писать цикл:
Код:
Asum := SumInt(m);
Amax := MaxIntValue(m);
Amin := MinIntValue(m);
{ср. ариф.}:= Mean(m)

Последний раз редактировалось AlexSku, 07.03.2008 в 12:35.
Ответить с цитированием
  #8  
Старый 07.03.2008, 12:40
Аватар для KOOL
KOOL KOOL вне форума
Активный
 
Регистрация: 06.01.2008
Адрес: Рязань
Сообщения: 306
Версия Delphi: 2009
Репутация: 6150
По умолчанию

Цитата:
Все равно не хочет работать, ни как не получается!
У меня все работает. Я уменьшил N до 50, и мин и макс значения стали меняться. Потом N вернул на 1000, а MAX_VALUE увеличил до 5000+1 - тоже меняются.
Тут все дело именно в N и MAX_VALUE. Если N слишком большое, то min всегда будет 0, а max - MAX_VALUE-1.
Ответить с цитированием
  #9  
Старый 07.03.2008, 12:43
Аватар для The Shadow
The Shadow The Shadow вне форума
Продвинутый
 
Регистрация: 11.06.2007
Адрес: Уфа, Россия
Сообщения: 793
Репутация: 35
По умолчанию

А вы Randomize то использовали?!
__________________
Что делать, когда сломался комп:
1. Если вы юзер - делать ноги.
2. Если ремонтник - делать деньги.
3. Если вы программист - делать вид, что так было задумано.
Ответить с цитированием
  #10  
Старый 07.03.2008, 12:52
Lukas Lukas вне форума
Прохожий
 
Регистрация: 06.03.2008
Сообщения: 5
Репутация: 10
По умолчанию

Все разобрался, Всем огромное спасибо за оказанную помощь!
Ответить с цитированием
  #11  
Старый 07.03.2008, 13:23
Lukas Lukas вне форума
Прохожий
 
Регистрация: 06.03.2008
Сообщения: 5
Репутация: 10
По умолчанию

Я конешно извиняюсь, но не могли бы вы мне снова помочь вот в чем! Надо сделать так, чтоб я задавал длину массива из строки ввода! Как мне это сделать?
Ответить с цитированием
  #12  
Старый 07.03.2008, 13:32
Аватар для The Shadow
The Shadow The Shadow вне форума
Продвинутый
 
Регистрация: 11.06.2007
Адрес: Уфа, Россия
Сообщения: 793
Репутация: 35
По умолчанию

Может динамическим массивом пойдет?
__________________
Что делать, когда сломался комп:
1. Если вы юзер - делать ноги.
2. Если ремонтник - делать деньги.
3. Если вы программист - делать вид, что так было задумано.
Ответить с цитированием
  #13  
Старый 07.03.2008, 13:40
Lukas Lukas вне форума
Прохожий
 
Регистрация: 06.03.2008
Сообщения: 5
Репутация: 10
По умолчанию

А как это реализовать в вышеприведенной программе?
Ответить с цитированием
  #14  
Старый 07.03.2008, 13:44
Аватар для The Shadow
The Shadow The Shadow вне форума
Продвинутый
 
Регистрация: 11.06.2007
Адрес: Уфа, Россия
Сообщения: 793
Репутация: 35
По умолчанию

Ну можно так:
Код:
procedure TfmExample.BEnterClick(Sender: TObject);
const
MAX_VALUE = 100+1;
var
   m: array of Integer;
   i: Integer;
   max,min: Integer;
   sum: Real;
   N: Integer;
begin
N:=StrToInt(Edit1.Text);
SetLength(m, N)
for i:=0 to N - 1 do
m[i]:= Random (MAX_VALUE);
sum:=0;
max := m[0];
min := m[0];
for i:= 0 to N - 1 do
begin
 sum :=sum+m[i];
if m[i]<min then min:= m[i]
else if m[i]>max then max:= m[i]
end;
 mmOutput.Lines.Add('Минимальное значение данного массива равно '+inttostr(min));
 mmOutput.Lines.Add('Среднее арифметическое число данного массива равно '+floattostr(sum/N));
 mmOutput.Lines.Add('Максимальное значение данного массива равно '+inttostr(max));
end;
Вроде все правильно.
__________________
Что делать, когда сломался комп:
1. Если вы юзер - делать ноги.
2. Если ремонтник - делать деньги.
3. Если вы программист - делать вид, что так было задумано.
Ответить с цитированием
  #15  
Старый 07.03.2008, 15:29
Phedor Phedor вне форума
Начинающий
 
Регистрация: 28.02.2008
Сообщения: 118
Репутация: 21
По умолчанию

А вам не кажется глупым два цикла делать тем более что мы САМИ генерируем значения массива?

Код:
procedure TfmExample.BEnterClick(Sender: TObject);
const
  Max_Value = 100;
var
  i, Min, Max, Sum: integer;
  m: array of Integer;
begin
  Randomize;
  Sum := 0;
  setlength(m, StrToInt(Edit1.Text));
  for i:=0 to length(m)-1 do
  begin
    m[i] := Round(Random(MaxValue));
    inc(Sum, m[i]);
    if i=0 then
    begin
      Max := m[i];
      Min := m[i];
    end else begin
      if m[i]<Min then Min := m[i];
      if m[i]>Max then Max := m[i];
    end;
  end;
 mmOutput.Lines.Clear;
 mmOutput.Lines.Add('Минимальное значение данного массива равно '+inttostr(Min));
 mmOutput.Lines.Add('Среднее арифметическое число данного массива равно '+floattostr(Sum/length(m)));
 mmOutput.Lines.Add('Максимальное значение данного массива равно '+inttostr(Max));
end;
Ответить с цитированием
Ответ


Delphi Sources

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

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

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

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


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


 

Сайт

Форум

FAQ

Соглашения

Прочее

 

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