Помощь - Поиск - Пользователи - Календарь
Полная версия: Задача на ссылочные типы данных
Форум «Всё о Паскале» > Pascal, Object Pascal > Задачи
Eskel
Вот задача:
Используя динамическое размещение последовательности вещественных чисел A1,A2…An, преобразовать исходную последовательность, добавив нулевые элементы после каждого отрицательного.


program Zadacha_1;

type
ptr=^arr;
arr=array[1..100] of real;


var
p:ptr;
q,i:word;
v:real;
begin
new(p);
writeln('Enter qantity of elements');
readln(q);
for i:=1 to q do
begin
writeln('Enter value of ',i,' element');
readln(p^[i]);
end;
writeln;
writeln('The list before processing:');
for i:=1 to q do
write(p^[i]:4 :2,', ');
writeln;
writeln('The list after processing:');
{for i:=1 to q do
begin
if p^[i]<0 then p^[i+1]:=0;
write(p^[i]:4 :2,', ');
end;}
dispose(p);
readln;
end.


Помогите, пожалуйста, написать сам цикл по добавлению нулей после отрицательных элементов
volvo
   writeln('The list before processing:');
for i:=1 to q do
write(p^[i]:4 :2,', ');
writeln;

i := q;
while i > 0 do begin
if p^[i] < 0 then begin
for j := q downto i do p^[j + 1] := p^[j];
p^[i + 1] := 0; inc(q);
end;
dec(i);
end;

writeln('The list after processing:');
for i:=1 to q do
write(p^[i]:4 :2,', ');
writeln;

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

Eskel
program Zadacha_1;

type
ptr=^arr;
arr=array[1..100] of real;


var
p:ptr;
q,i,j:word;
v:real;
begin
new(p);
writeln('Enter qantity of elements');
readln(q);
for i:=1 to q do
begin
writeln('Enter value of ',i,' element');
readln(p^[i]);
end;
writeln;
writeln('The list before processing:');
for i:=1 to q do
write(p^[i]:4 :2,', ');
writeln;
i:=q;
while i>0 do begin
if p^[i]<0 then begin
for j:=q downto i do p^[i+1]:=p^[i];
p^[i+1]:=0; inc(q) end;
dec(i) end;
writeln('The list after processing:');
for i:=1 to q do
write(p^[i]:4 :2,', ');
writeln
dispose(p);
readln;
end.


Я вот так переделал... Правильно? У меня не работает.

Еще. Покажите, пожалуйста, покажите как сделать эту прогу как вы сказали. Будет 2 варианта rolleyes.gif
volvo
   for j:=q downto i do p^[i+1]:=p^[i];
Я этого не говорил. Смотри внимательнее.
Eskel
Спасибо, исправил. Получилось
volvo
А вот - тот вариант, о котором я написал выше, с перераспределением памяти:
program Zadacha_1;

type
ptr = ^arr;
arr = array[1 .. 1000] of real;

var
p,pt:ptr;
q,i,j,count:word;
v:real;
begin
writeln('Enter qantity of elements');
readln(q);

getmem(p, q * sizeof(real));
for i:=1 to q do
begin
writeln('Enter value of ',i,' element');
readln(p^[i]);
end;

writeln;
writeln('The list before processing:');
for i:=1 to q do
write(p^[i]:4 :2,', ');
writeln;

count := 0;
for i := 1 to q do begin
if p^[i] < 0 then inc(count);
end;

if count > 0 then begin
getmem(pt, (q + count) * sizeof(real));
j := 1;
for i := 1 to q do begin
pt^[j] := p^[i]; inc(j);
if p^[i] < 0 then begin
pt^[j] := 0; inc(j);
end;
end;
freemem(p, q * sizeof(real));
inc(q, count);
p := pt;
end;

writeln('The list after processing:');
for i:=1 to q do
write(p^[i]:4 :2,', ');
writeln;

freemem(p, q * sizeof(real));
readln;
end.
Это текстовая версия — только основной контент. Для просмотра полной версии этой страницы, пожалуйста, нажмите сюда.