Надеюсь я не сильно надоедаю своими дурацкими задачами
Вот код:
program _2;
uses crt;
const k=100;
type intarr=array[1..k] of integer;
type arr=array[1..k] of real;
var n,i,j,c,f:integer;
a,h,x:real;
R:arr;
numofneg:intarr;
procedure writearray(n:integer; R:arr);
var i:integer;
begin
for i:=1 to n do writeln('R[',i,']=',R[i]);
end;
function findmaxn(n:integer; R:arr):integer;
var c,i:integer;
max:real;
begin
c:=0;
max:=R[1];
for i:=1 to n do begin if max<R[i] then begin max:=R[i]; findmaxn:=i; end; end;
end;
begin
c:=0;
j:=0;
clrscr;
writeln('Input following values (N must be less then 20):');
repeat begin write('N='); readln(n); end;
until n<20;
write('X='); readln(x);
write('H='); readln(h);
write('A='); readln(a);
for i:=1 to n do R[i]:=0.8*cos(a*x+i*h);
writeln('Your array R is:');
writearray(n,R);
writeln('---------------------');
for i:=findmaxn(n,R) to n do if R[i]>0 then begin inc(j); numofneg[j]:=i; end;
writeln(findmaxn(n,R));
writeln('---------------------');
{вот тут как мне кажется ошибка->} for i:=1 to j do begin for f:=numofneg[i] to n-j do begin inc©; R[f]:=R[f+1]; end; end;
writeln('After deliting we have:');
writearray(c,R);
readln;
end.
c := n;
for i := j downto 1 do
begin
for f := numofneg[i] to c - 1 do
R[f] := R[f+1];
dec( c );
end;
zloy_pes, лишние переменные - Зло :)
И с ними надо бороться ... Заодно посмотри на переделанную функцию findmaxn...
uses crt;
const
k = 100;
type
arr = array[1..k] of real;
var
n,i,j: integer;
a,h,x: real;
R: arr;
procedure writearray(n:integer; R:arr);
var i: integer;
begin
for i:=1 to n do
writeln('R[',i,']=',R[i]:10:7);
end;
function findmaxn(n:integer; R:arr):integer;
var i, max: integer;
begin
max := 1;
for i:=1 to n do
if R[max] < R[i] then max := i;
findmaxn := max;
end;
begin
clrscr;
writeln('Input following values (N must be less then 20):');
repeat
write('N='); readln(n);
until n<20;
write('X='); readln(x);
write('H='); readln(h);
write('A='); readln(a);
for i:=1 to n do
R[i]:=0.8*cos(a*x+i*h);
writeln('Your array R is:');
writearray(n,R);
writeln('---------------------');
i := findmaxn(n, R) + 1;
while i <= n do
if R[i] > 0 then begin
for j := i to n - 1 do
R[j] := R[j + 1];
Dec(n)
end
else inc(i);
writeln('---------------------');
writeln('After deleting we have:');
writearray(n,R);
readln;
end.
Программа попрежнему работает странно Вместо того, чтобы выводить только отрицательные числа, там появляются ещё и положительные
Но за помощь спасибо - продолжаю думать...
zloy_pes,
Уважаемый, но так у тебя написано... Значит, переформулируй задание!!! Здесь не форум телепатов, чтоб ГАДАТЬ, что тебе нужно.
Хорошо, вообщем задание такое:
1. Сформировать массив R, в котором элемент r(i)=0,8*cos(a*x+h*i), где i=1..n (n - натуральное, задаётся с клавиатуры n<20) и x,h,a - действительные числа - тоже с клавы.
2. В вычесленном массиве удалить все положительные элементы, расположенные после максимального.
Угу... А теперь - вопрос на засыпку... Какой из пунктов задания, моя программа НЕ выполняет ? Что она делает "слишком просто" ? Я в задании никакого указания на сложность не видел...
Будем гадать дальше ?
Ой! Точно! Приношу свой извинения! Неправильно понял задачу.
2volvo Спасибо огромное!