IPB
ЛогинПароль:

> Прочтите прежде чем задавать вопрос!

1. Заголовок темы должен быть информативным. В противном случае тема удаляется ...
2. Все тексты программ должны помещаться в теги [code=pas] ... [/code].
3. Прежде чем задавать вопрос, см. "FAQ", если там не нашли ответа, воспользуйтесь ПОИСКОМ, возможно такую задачу уже решали!
4. Не предлагайте свои решения на других языках, кроме Паскаля (исключение - только с согласия модератора).
5. НЕ используйте форум для личного общения, все что не относится к обсуждению темы - на PM!
6. Одна тема - один вопрос (задача)
7. Проверяйте программы перед тем, как разместить их на форуме!!!
8. Спрашивайте и отвечайте четко и по существу!!!

> сортировка Шелла, подскажите, пожалуйста.
Triplet
сообщение 25.05.2008 8:48
Сообщение #1


Пионер
**

Группа: Пользователи
Сообщений: 78
Пол: Женский

Репутация: -  0  +


Подскажите, пожалуйста, в чем ошибка?
program Project2;

{$APPTYPE CONSOLE}

uses
SysUtils;
Type TBase=record
Key:integer;
end;
Index=1..20000;
Vector=array[Index] of TBase;

Function Shell(var x:vector;n:integer):vector;
Var t,m,h:integer;
i,j:index;
y:TBase;
begin
t:=round(ln(n)/ln(2))-1;
for m:=t downto 1 do
begin
h:=0;
for i:=1 to m do h:=2*h+1; //h - шаг сортировки
for i:=h+1 to N do
begin
y:=x[i];j:=i-h;
while (j>=1) and (y.key<x[j].Key) do
begin
x[j+h]:=x[j];
j:=j-h;
end;
x[j+h]:=y;
end;
end;
Shell:=x;
end;


Var z,n:integer;x,qwer:vector;
begin
n:=10; //кол-во элементов массива
Randomize;
for z:=1 to n do
begin
x[z].key:=Random(20);
Writeln(x[z].key);
end;
qwer:=Shell(x,n);
Writeln;
for z:=1 to n do
Writeln(qwer[z].key);
Readln;
end.




Иногда программа работает исправно, а иногда вылетает на строче x[j+h]:=y; в функции unsure.gif
Заранее спасибо
 Оффлайн  Профиль  PM 
 К началу страницы 
+ Ответить 
 
 Ответить  Открыть новую тему 
Ответов
volvo
сообщение 25.05.2008 9:11
Сообщение #2


Гость






Я бы на твоем месте все-таки не вычитал содержимое переменной типа Integer из содержимого переменной типа Index (имеющего меньший диапазон), да еще и занося результат в Index вот тут:
y:=x[i];
j:=i-h; { <--- }

Поменяй типы I и J на Integer, все должно нормализоваться...

P.S. Должно быть достаточно поменять только тип переменной J...

Сообщение отредактировано: volvo - 25.05.2008 9:14
 К началу страницы 
+ Ответить 

Сообщений в этой теме


 Ответить  Открыть новую тему 
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0

 



- Текстовая версия 18.07.2025 17:01
Хостинг предоставлен компанией "Веб Сервис Центр" при поддержке компании "ДокЛаб"