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

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

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

> код даВинчи)
Elmo
сообщение 17.03.2007 20:47
Сообщение #1





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

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


Пожалуйста, помогите выправить программу. Вроде бы должна нормально работать, но в конце выводит что-то несуразное.
Условие таково:
Задание: ввести два вектора A(n) и B(n), определить новый вектор Z как Z=A*+B*, где "*" означает, что все компоненты этого вектора получены из исходного путём деления на максимальную компоненту этого вектора (производится нормировка). При решении использоватьпроцедуры и функции.
А вот код:

program lab;
uses crt;
type mas=array[1..50] of real;
var
z,x,y:mas;
n:byte;

procedure input(var a:mas;m:byte;c:char);
var i:integer;
begin
for i:=1 to m do
begin
write(c,'[',i,']=');
read(a[i])
end
end;

function max(var a:mas;m:byte):real;
var j:integer;
d:real;
begin
a[1]:=d;
for j:=2 to m do
begin
if a[j]>d then a[j]:=d;
max:=d;
end;
end;

procedure norm(var a:mas;m:byte);
var j:integer;
begin
for j:=1 to m do
a[j]:=a[j]/max(a,m);
end;

procedure sum(var c:mas;a,b:mas;m:byte);
var j:integer;
begin
for j:=1 to m do
c[j]:=a[j]+b[j];
end;
procedure print(a:mas;m:byte;c:char);
var
j:integer;
begin
for j:=1 to m do
write(z[j]:6:2);
end;
begin
clrscr;
write('n=');
read(n);
input(x,n,'x');
input(y,n,'y');
norm(x,n);
norm(y,n);
sum(z,x,y,n);
print(z,n,'z');
end.



 Оффлайн  Профиль  PM 
 К началу страницы 
+ Ответить 
 
 Ответить  Открыть новую тему 
Ответов
volvo
сообщение 17.03.2007 21:05
Сообщение #2


Гость






function max(var a:mas;m:byte):real;
var
j:integer;
d:real;
begin
d := a[1]; { вместо a[1]:=d; }
for j:=2 to m do
begin
if a[j]>d then d := a[j]; { <--- вместо a[j] := d; }
end;
max:=d; { <--- на одну строку ниже, чем было }
end;

Должно работать нормально ...

Сообщение отредактировано: volvo - 17.03.2007 21:11
 К началу страницы 
+ Ответить 
Elmo
сообщение 17.03.2007 21:13
Сообщение #3





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

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


Цитата(volvo @ 17.03.2007 21:05) *

function max(var a:mas;m:byte):real;
var
j:integer;
d:real;
begin
d := a[1]; { вместо a[1]:=d; }
for j:=2 to m do
begin
if a[j]>d then d := a[j]; { <--- вместо a[j] := d; }
end;
max:=d; { <--- на одну строку ниже, чем было }
end;

Должно работать нормально ...

В конце выводит матрицу, все элементы которой равны 2.00, не зависимо от того, что вводим вначале
 Оффлайн  Профиль  PM 
 К началу страницы 
+ Ответить 

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


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

 



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