![]() |
|
|
Регистрация | << Правила форума >> | FAQ | Пользователи | Календарь | Поиск | Сообщения за сегодня | Все разделы прочитаны |
![]() |
|
Опции темы | Поиск в этой теме | Опции просмотра |
|
#1
|
|||
|
|||
![]() Спасибо тем, кто откликнулся на мою первую мольбу о помощи, задачка сдалась только с небольшими изменениями... Очень-очень благодарна!!!! Вот только опять попала, массивы-это явно не моя тема, утонула в ней, две задачки покорились, а эта опять зависла!!!!!! Помогите, пожалуйста! используя следующий фрагмент программы, найдите наибольшее расстояние d между точками, рассматривая элементы массива М, как координаты точек плоскости: type точка=array [(x,y)] of real; var M: array [1..40] of точка; d:real ![]() |
#2
|
|||
|
|||
![]() Волновой алгоритм используй
|
#3
|
|||
|
|||
![]() Какой алгоритм???
Тут тупое вычисление расстояний между всеми точками и выбор максимального значения. Расстояние высчитывается по формуле пифагора: d := sqrt(sqr(x1-x2) + sqr(y1-y2)); Дальше перебираешь все точки массива попарно и считаешь расстояние между ними. Код:
uses math; var i, j : integer; begin d := 0; for i := 1 to 39 do for j := i+1 to 40 do d := max(d,sqrt(sqr(M[i][x]-M[j][x]) + sqr(M[i][y]-M[j][y]))); end; |
#4
|
|||
|
|||
![]() Спасибочки за идею, только там еще элемент Delphi надо использовать: StringGrid с двумя строками и 20 столбцами, я потом с его элементами сделать ничего не могу, там столько ошибок выдается: и real не подходит, и элементы введены неправильно...
|
#5
|
|||
|
|||
![]() За место real используй double.
Не совсем понятно зачем именно такой StringGrid. Даже если вводить через него данные, то все-равно нужно либо 2 столбца и 40 строк, либо 40 столбцов и 2 строки. вообще, когда писал код думал что это некоторая абстрактная задача, т.к. ни Дельфи, ни Паскаль НЕ ПОНИМАЮТ ИДЕНТИФИКАТОРОВ на русском языке. для начала я бы постановку задачи переписал следующим образом: Код:
type TDblPoint = record x : double; y : double; end; var M : Array [1..40] Of TDblPoint; d : double; Тогда мой код надо немного поменять: Код:
uses math; var i, j : integer; begin d := 0; for i := 1 to 39 do for j := i+1 to 40 do d := max(d,sqrt(sqr(M[i].x-M[j].x) + sqr(M[i].y-M[j].y))); end; И вот это вполне скомпилится и должно работать. Здесь нет задачи значений для точек. Его как раз можно сделать через StringGrid. Предполягаем, что в StringGrid 3 колонки (1 фиксированная с названиями кординат - х и у) и 41 строка (1 фиксированая с номерами точек). Тогда считывание значений будет выглядеть так: Код:
var i : integer; begin For i := 1 To 40 Do Try M[i].x := StrToFloat(StringGrid1.Cells[1,i]); M[i].y := StrToFloat(StringGrid1.Cells[2,i]); Except // Если не удалось конвертировать из строки в число. M[i].x := 0; M[i].y := 0; End; end; |
#6
|
|||
|
|||
![]() Что значит сообщение "ProjectProject1.exe raised exception class EConvertError winh message "is not a valid integer value". Process stopped. Use step or Run to continue.".
Admin: Не стоит выделять жирным/курсивом и т.п. все подряд, и без этого все прекрасно читается. Последний раз редактировалось Admin, 13.05.2008 в 11:16. |