539

Обработка одномерных массивов. Выделение минимального и максимального элементов массива

Лабораторная работа

Информатика, кибернетика и программирование

Найти максимальный элемент и поменять его местами со вторым элементом массива. Таблица используемых переменных и компонентов. Максимальный и минимальный элемент массива и его место в массиве.

Русский

2013-01-06

104 KB

81 чел.

МИНИСТЕРСТВО ОБРАЗОВАНИЯ РЕСПУБЛИКИ БЕЛАРУСЬ

УЧРЕЖДЕНИЕ ОБРАЗОВАНИЯ

«ГОМЕЛЬСКИЙ ГОСУДАРСТВЕННЫЙ ТЕХНИЧЕСКИЙ УНИВЕРСИТЕТ ИМЕНИ П.О. СУХОГО»

Факультет автоматизированных и информационных систем

Кафедра «Информатика»

Отчёт по лабораторной работе №7

«Обработка одномерных массивов. Выделение минимального и максимального элементов массива»

Выполнил студент гр. ГА-11

Луцко А.Н.

Принял преподаватель

Мисюткин В.И.

Дата допуска к защите __________

Дата защиты __________

Гомель 2012


Цель работы
: Получить навыки разработки и реализации типовых алгоритмов обработки одномерных массивов на языке Delphi. Научиться находить максимальный и минимальный элемент массива и определять его место в массиве; изменять значения и расположение элементов массива; обрабатывать элементы массива, находящиеся перед (после) максимальным (минимальным) элементом.

Задание: В каждой из задач предполагается, что задан массив  чисел. Программа должна:

1) вводить размерность и элементы исходного массива;

2) выполнять действия в соответствии с условием задачи;

3) выводить:

  •   исходный массив;
  •        максимальный или минимальный элемент массива и его номер;
  •   массив, полученный в результате выполнения задания;
  •   сообщение о том, что перестановка не нужна или невозможна.

Исходные данные для отладки программы выбрать самостоятельно. Для ввода и вывода массива использовать  визуальный компонент StringGrid.

Задача: Найти максимальный элемент и поменять его местами со вторым элементом массива.

Вид окна формы

Таблица свойств компонентов

Элемент интерфейса

Компонент

Свойство

Значение свойства

Заголовок окна

Form1

Caption

Лаба 7

Размермассива

Label1

Caption

Размерность массива:

Поле ввода размера массива

Edit1

Text

Кнопка Вычислить

Button1

Caption

ОК

Таблица для ввода значений

StringGrid1

FixedRows

FixedCols

ColCount

RowCount

goEditing

0

0

20

1

True

Таблица для вывода значений

StringGrid2

FixedRows

FixedCols

ColCount

RowCount

goEditing

0

0

20

1

False

Таблица используемых событий

Компонент

Событие

Имя процедуры обработки события

Реализуемый алгоритм

Button1

OnClick

TForm1.Button1Click

Вычисление

Edit1

OnChange

TForm1.Edit1Change

Изменение размера массива

Таблица используемых переменных

Имя переменной в задаче

Имя переменной в программе

Тип переменной

Комментарий

-

x

array[1..20] of real

Массив исходных значений

-

i

integer

Текущий элемент массива

N

n

integer

Размер  массива

-

maxn

integer

Номер максимального элемента

-

max

real

Максимальный элемент

-

t

real

Второй элемент массива

                                                           

 

Cхема алгоритма

    

Текст модуля

unit Unit1;

interface

 //Выполнил Луцко А.Н.

uses

 Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms,

 Dialogs, StdCtrls, Grids;

type

 TForm1 = class(TForm)

   Edit1: TEdit;

   StringGrid1: TStringGrid;

   StringGrid2: TStringGrid;

   Button1: TButton;

   Label1: TLabel;

   procedure Button1Click(Sender: TObject);

   procedure Edit1Change(Sender: TObject);

 private

   { Private declarations }

 public

   { Public declarations }

 end;

var

 Form1: TForm1;

implementation

{$R *.dfm}

procedure TForm1.Button1Click(Sender: TObject);

Var

x:array[1..20] of real;

i, n,maxn: integer;

max,t:real;

begin

n:=strtoint(edit1.text);

for i:=1 to n do

x[i] := StrtoFloat(StringGrid1.Cells[i - 1,0]);

 max := x[1];

 maxn := 1;

 for i := 2 to n do

   if max < x[i] then

   begin

     max := x[i];

     maxn := i;

   end;

  if maxn=2 then

   showmessage('перестановка не требуется')

   else

   begin

 t := x[2];

 x[2] := max;

 x[maxn] := t;

   end;  

showmessage('максимальный элемент='+floattostr(max));

 showmessage ('номер максимального элемента='+ inttostr(maxn));

 for i := 1 to n do begin

   StringGrid2.Cells[i - 1,0] := FloatToStr(x[i]);

 end;

end;

procedure TForm1.Edit1Change(Sender: TObject);

begin

 StringGrid1.ColCount := StrToInt(Edit1.Text);

 StringGrid2.ColCount := StrToInt(Edit1.Text);

end;

end.

Тест

Исходные данные: n = 5

1

0

23

4,5

84

Ожидаемый результат :

1

84

23

4,5

0

Результат в программе:

1

84

23

4,5

0

Тест2

Исходные данные: n = 5

1

84

23

4,5

0

Ожидаемый результат :

1

84

23

4,5

0

Результат в программе:

1

84

23

4,5

0

  

Вывод: Получил навыки разработки и реализации типовых алгоритмов обработки одномерных массивов на языке Delphi. Научился находить максимальный и минимальный элемент массива и определять его место в массиве; изменять значения и расположение элементов массива; обрабатывать элементы массива, находящиеся перед (после) максимальным (минимальным) элементом.


конец

Вывод x

Перестановка не требуется

Да

Нет

Max=2

начало

x[maxn] = t

x[2] = max

t = x[2]

i= i+1

maxn = i

max = x[i]

Нет

Да

max<x[i]

Да

i <= n

i = 2

Maxn=1

= 1

max = x[1]

Считывание элементов таблицы в массив

Ввод a,b, элементов массива


 

А также другие работы, которые могут Вас заинтересовать

72174. Трудовые споры. Коллективные и индивидуальные трудовые споры 21.5 KB
  Право на индивидуальные и коллективные трудовые споры с использованием установленных федеральным законом способов их разрешения провозглашенное ч. Коллективные трудовые споры рассматриваются в порядке определяемом федеральным законом.
72175. Рабочее время и время отдыха 31.5 KB
  Трудовой кодекс не изменяет установленные КЗоТом нормальную продолжительность рабочего времени не более 40 часов в неделю и сокращенную продолжительность рабочего времени для определенных категорий работников. В соответствии со статье 94 ТК РФ продолжительность ежедневной работы...
72176. Прекращение трудовых отношений 33.5 KB
  Удельный вес различных оснований прекращения трудового договора в общем объеме увольнений неоднозначен. Наиболее распространенными основаниями расторжения трудового договора являются увольнения по инициативе работника и по инициативе работодателя и поэтому они нуждаются...
72177. Понятия и принципы уголовного права 31 KB
  С этих исходных позиций мы сможем со знанием дела уяснить понятие и круг источников уголовного права их содержание. Уголовное право как отрасль права традиционно определяется как совокупность юридических норм которые устанавливают преступность и наказуемость деяний представляющих...
72178. Наказание. Понятие, цели и виды 60.5 KB
  Надо добавить что назначение и исполнение наказания означает в то же время порицание судом от имени государства содеянного виновным и его самого как нанесшего вред обществу. Иными словами содержанием наказания является кара за преступление о чем уже упоминалось в связи с общей...
72179. Понятие административного права 48.5 KB
  Административное право представляет собой совокупность правовых норм регулирующих определенные сферы общественных отношений составляющих предмет этой отрасли права. При этом предмет административного права отвечает на вопрос что какие общественные отношения регулируются нормами...
72180. Административные правонарушения в РФ 63 KB
  Нарушение правил о которых говорилось выше иногда может повлечь уголовную ответственность если это прямо предусмотрено Уголовным кодексом. Для подобных случаев а они наиболее часты государство и учредило административную ответственность которая по характеру мер менее сурова...
72181. ПРАКТИЧЕСКИЕ СХЕМЫ ВЫСОКОКАЧЕСТВЕННОГО ЗВУКОВОСПРОИЗВЕДЕНИЯ 1.68 MB
  Каждый из этих узлов имеет самостоятельное значение и характеризуется своими показателями качества влияющими на качество всего усилителя в целом. Структурную схему современного усилителя высококачественного звуковоспроизведения УВЗ можно представить в виде совокупности различных модулей...
72182. Економіка підприємства: Методичні рекомендації 902 KB
  Методичні рекомендації містять стислі рекомендації до виконання курсової роботи та провідні методичні положення щодо обґрунтування прийнятих студентом рішень підвищення ефективності роботи підприємства цеху виходячи з заданих економічних умов вимоги до курсової роботи порядок її виконання.