• Добро пожаловать на компьютерный форум Tehnari.ru. Здесь разбираемся с проблемами ПК и ноутбуков: Windows, драйверы, «железо», сборка и апгрейд, софт и безопасность. Форум работает много лет, сейчас он переехал на новый движок, но старые темы и аккаунты мы постарались сохранить максимально аккуратно.

    Форум не связан с магазинами и сервисами – мы ничего не продаём и не даём «рекламу под видом совета». Отвечают обычные участники и модераторы, которые следят за порядком и качеством подсказок.

    Если вы у нас впервые, загляните на страницу о проекте, чтобы узнать больше. Чтобы создавать темы и писать сообщения, сначала зарегистрируйтесь, а затем войдите под своим логином.

    Не знаете, с чего начать? Создайте тему с описанием проблемы – подскажем и при необходимости перенесём её в подходящий раздел.
    Задать вопрос Новые сообщения Как правильно спросить
    Если пришли по ссылке со старого Tehnari.ru – вы на нужном месте, просто продолжайте обсуждение.

Подпрограммы и записи в паскаль

кусака

Ученик
Регистрация
13 Июн 2010
Сообщения
4
Реакции
0
Баллы
0
Подпрограммы и записи в паскаль

помогите пожалуйста!

1) заданы окружность (x-a)^2+(y-b)^2=r^2 и две точки p={p1,p2} и f(f1,f2} вычислить сколько точек лежит внутри окружности. проверку принадлежности точки к окружности оформить в виде функции.
данные: а=3.2, в=4.1 r=2. p,f - произвольно.

2)вычислить Z= (s1+s2)/(k1*k2), где s1,k1 - сумма и кол-во положительных элементов массива Х(n), s2,k2 - сумма и кол-во положительных эл-тов массива Y(m). вычисления суммы и кол-ва положительных элементов массива оформить как процедуру.
данные произвольные.

3) задачка на записи:
для каждого студента указаны фамилия имя и оценки по 3м дисциплинам. требуется вычислить средний бал каждого студента и упорядочить список по убыванию среднего бала. вывод на экран оформить в виде таблицы.
 
А почему бы вам самому не попробовать, и задать конкретные вопросы по тому, что не понятно, что не получается?
 
хорошо. скажите как оформить в виде таблицы и отсортировать по убыванию?
 
алгоритм сортировки простого массива знаете? вот и вся сортировка. А про вывод в виде таблицы, почитайте справку в паскале на процедуру gotoxy(x,y);
пример:
Код:
uses crt;
var i:word;
begin clrscr;
writeln ('Table');
for i:=1 to 3 do begin
 gotoxy(3,i+2);
 write ('Student', i);
 gotoxy (15,i+2);
 write ('Surname', i);
 gotoxy (25,i+2);
 write ('mark', i);
end;
gotoxy(1,i+4);
readkey;
end.
 
Последнее редактирование:
Первая задача выглядит примерно так:
Код:
program z1;

type 
	point = record
		x, y: real;
	end;

const
	a = 3.2;
	b = 4.1;
	r = 2;

function proverka (p: point): boolean;
begin
	proverka:=false;
	if sqr(p.x-a)+sqr(p.y-b)<sqr(r) then
		proverka:=true;
end;

var
	p, f: point;
	n: integer;

begin
	writeln('Vvedtie koorinaty tochki p:');
	readln(p.x, p.y);
	writeln('Vvedtie koorinaty tochki f:');
	readln(f.x, f.y);
	n:=0;
	if proverka(p)=true then n:=n+1;
	if proverka(f)=true then n:=n+1;
	writeln('Kolichestvo tochek = ', n);
	readln
end.
Вроде проверил, все работает. Пользуйся, студент :-)
 
приятно видеть, что одни новички помогают другим.. NDV, так держать :)
 
спасибо)))
только еще скажите почему в последней строчке выдает 64 ошибку?

program ex18;
const n=3; {kol-vo predmetov}
type st=record
fam:string;
im:string;
oc:array[1..n] of integer;
end;
var j,k,i:integer;
t:array[1..30]of st;
begin
writeln('vvedite kol-vo studentov');
readln(k);
for i:=1 to k do
writeln('vvedite familii');
readln(t.fam);
writeln('vvedite ima');
readln(t.im);
writeln('ocenci');
for j:=1 to n do
readln(t[j].oc);
 
ос - массив, значит и вводить надо соответственно - oc
 
А программа здесь специально не вся? И в цикле че-то не понял, где фамилии заполняются: там операторных скобок нету
 
спасибо)
 
Последнее редактирование:
В цикле
for i:=1 to k do
writeln('vvedite familii');
readln(t.fam);
writeln('vvedite ima');
readln(t.im);
writeln('ocenci');
for j:=1 to n do
readln(t[j].oc);

должно быть так:
Код:
for i:=1 to k do
begin
 writeln('vvedite familii');
 readln(t[i].fam);
 writeln('vvedite ima');
 readln(t[i].im);
 writeln('ocenci');
end;
Связка begin...end и называется операторными скобками
 
Да, и еще. Что бы каждый раз не писать t.поле, можно использовать оператор with t do begin ... end; который позволяет общаться к полям выбранной записи просто по имени самих полей. Удобно, если имя записи велико и нагружает код. То есть, вашу программу можно исправить так:

for i:=1 to k do
with t do begin
writeln('vvedite familii');
readln(fam);
writeln('vvedite ima');
readln(im);
writeln('ocenci');
end;
в общем и старый вариант будет работать, это просто оптимизация

Ввод оценок можно организовать так (при фиксированном n):
(...)
writeln('ocenci');
readln (oc[1],oc[2],oc[3]);
end;
или же так, как вы хотели
for j:=1 to n do
readln (t.oc[j])
 
Последнее редактирование:
Назад
Сверху