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

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

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

 
 Ответить  Открыть новую тему 
> Задача на логическую функцию
Lodar'
сообщение 29.01.2009 14:15
Сообщение #1


Новичок
*

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

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


Составить логическую функцию proba(A,n) принимающую значение true, если компоненты вектора А образуют арифметическую прогрессию, и значение false - в противном случае.
Вот мои наработки:

program Pr2;
const
maxsize=100;
type
tvector=array [1..maxsize] of integer;
function proba (A: tvector; n:integer):boolean;
var
i:integer;
c:array [1..(maxsize-1)] of integer;
begin
for i:=1 to n-1 do
begin
c[i]:=A[i+1]-A[i];
end;
for i:=1 to n-1 do
begin
if c[i]=c[i+1] then continue
else
begin
result:=false;
exit;
end;
end;
result:=true;
end;

var
B:tvector;
n,i: integer;
D:boolean;
begin
writeln('введите размерность вектора');
readln(n);
for i:=1 to n do
begin
writeln('введите',i,'й элемент вектора');
readln(B[i]);
end;
D:=proba(B,n);
if D then writeln('да, арифметическая прогрессия')
else writeln('нет, не арифметическая прогрессия');
readln;
end.

нормально? или можно что нибудь улучшить чтоб было более рационально? подскажите пожалуйста!
 Оффлайн  Профиль  PM 
 К началу страницы 
+ Ответить 
volvo
сообщение 29.01.2009 14:21
Сообщение #2


Гость






Цитата
нормально? или можно что нибудь улучшить чтоб было более рационально?
Можно и улучшить... Например, непонятно, зачем тебе еще один массив. Не проще ли запомнить разность между первым и вторым элементами массива, а потом проверять все остальные разности? Вот так как-нибудь:
function proba (A: tvector; n:integer):boolean;
var
i, delta: integer;
begin
delta := a[2] - a[1];
result := false;
for i := 1 to n - 1 do begin
if (A[i+1] - A[i]) <> delta then exit;
end;
result := true;
end;

?
 К началу страницы 
+ Ответить 
Lodar'
сообщение 29.01.2009 15:03
Сообщение #3


Новичок
*

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

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


Cпасибо за совет) учту.
 Оффлайн  Профиль  PM 
 К началу страницы 
+ Ответить 

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

 



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