Студопедия Главная Случайная страница Обратная связь

Разделы: Автомобили Астрономия Биология География Дом и сад Другие языки Другое Информатика История Культура Литература Логика Математика Медицина Металлургия Механика Образование Охрана труда Педагогика Политика Право Психология Религия Риторика Социология Спорт Строительство Технология Туризм Физика Философия Финансы Химия Черчение Экология Экономика Электроника

While not eof(input) do begin


В вестибулярной норме форма коронки ромбовидная, но с закругленными углами. Жевательная поверхность двухбугорковая. Размеры бугорков практически одинаковы. Корень одиночный. На аппроксимальной поверхности корня хорошо видны вертикальные бороздки, особенно на дистальной поверхности.

1. О каком зубе идет речь?

2. Какие возможны аномалии развития этих зубов?

Ответ

1. Речь идет о втором верхнем премоляре.

2. Часто встречается адентия и гиподентия второго верхнего премоляра. Адентия сопровождается появлением трем между клыком и первым премоляром. Редкая аномалия - транспозиции, при котором первый второй премоляр меняются местами (или первый премоляр меняется с клыком). Краудинг (скученность зубов) также достаточно часто встречается у дистальных премоляров.

 

Type

zvonki = record {Задаем запись}

name: string;

time: integer;

pow: integer;

end;

 

Var

wizard: array [1..10000] of zvonki; {масссив записей}

I, n, j, tmp, ps, kod: integer;

tmp1, s, times: string;

 

// ПРОЦЕДУРЫ

procedure time_sort(x: integer); { процедуры обмена значениями двух переменных}

Begin

tmp:= wizard[x].time;

wizard[x].time:= wizard[x + 1].time;

wizard[x + 1].time:= tmp;

end;

 

procedure power_sort(x: integer);

Begin

tmp:= wizard[x].pow;

wizard[x].pow:= wizard[x + 1].pow;

wizard[x + 1].pow:= tmp;

end;

 

procedure names_sort(x: integer);

Begin

tmp1:= wizard[x].name;

wizard[x].name:= wizard[x + 1].name;

wizard[x + 1].name:= tmp1;

end;

 

Begin

 

/ / СЧИТЫВАНИЕ ИЗ ФАЙЛА

assign(input, 'input.txt'); reset(input); {открываем input.txt}

assign(output, 'output.txt'); rewrite(output);

readln(n); {считываем количество волшебников}

for I:= 1 to n do

Begin

readln(s); {считываем всю строку из файла.}

PS:= Pos(' ', s); {функция pos() определяет позицию любого символа в строке. если символов несколько, выводит координату первого}

wizard[I].name:= Copy(S, 1, PS - 1); {Копируем имя без пробела}

Delete(s, 1, PS); {Удаляем имя с пробелом}

PS:= Pos(' ', S); {Определяем позицию пробела}

times:= Copy(S, 1, PS - 1); {Копируем строку во временную переменную}

Val(times, wizard[I].time, kod); {Используем стандартную функцию преобразования типов.}

Delete(S, 1, PS); {Удаляем все лишнее}

Val(S, wizard[I].pow, kod); {Трансформируем оставшуюся строку в целое число.}

end;

// ТЕЛО ПРОГРАММЫ

for I:= 1 to n - 1 do {сортируем пузырьком}

for j:= 1 to n - i do

Begin

if wizard[j + 1].time > wizard[j].time then { Если время разговора волшебника больше времени следующего волшебника}

Begin

time_sort(j); {обмениваем значения времени}

names_sort(j); {обмениваем значения имен}

power_sort(j); {обмениваем значения сил. таким образом мы перемещаем волшебника с меньшим временем разговора вниз}

end;

if wizard[j + 1].time = wizard[j].time then begin {Если время разговора волшебников одинаково, то}

if wizard[j + 1].pow < wizard[j].pow then {Если сила одного меньше силы другого, то}

Begin

power_sort(j); {обмениваем значения сил}

names_sort(j); {обмениваем значения имен}

// Время у них и так одинаковое, поэтому нет смысла производить обмен времени.

End

Else

if wizard[j + 1].pow = wizard[j].pow then {Если же сила у них равна}

if wizard[j + 1].name < wizard[j].name then {Сравниваем имена.}

names_sort(j); {обмениваем значения имен}

// Время и сила у них одинаковое, поэтому мы обмениваем только имена.

end;

end;

// ВЫВОД

for i:= 1 to n do writeln(output, wizard[i].name);

close(input);

close(output);

End.

 

 

Решение задачи Перевозка грузов

Обозначим: k - номер рейса судна, i - номер очередного груза, s - масса груза на судне в k-том рейсе. Решать задачу будем так: если на судно в k-том рейсе можно поместить ещё один груз, то мы грузим его и берём следующий, если груз не может быть размещен, то перевозим его следующим рейсом (увеличиваем k).

program perevozka;

type massiv=array of integer;

Var

m:massiv;

k,s,i:integer;

input, output: text;

 

Begin

assign(input,'input.txt');

reset(input);

i:= -1;

while not eof(input) do begin

Inc(i);

SetLength(m, i + 1);

Read(input, m[i]);

//writeln(m[i]);

Readln(input);

end;

close(input);

 

assign(output,'output.txt');

rewrite(output);

i:=1;

k:=1;

s:=0;

repeat if s+m[i]<=50 then

Begin

s:=s+m[i];

i:=i+1;

End

else if m[i]<=50 then

begin k:=k+1;

s:=0;

End

Else

Begin

k:=0;

Break;

end;

until i>m[0];

if k<>0 then write(output,'Vsego potrebovalos ', k,' reysov')

else write(output,'Odin iz gruzov vesit bolshe 50 tonn');

Close (output);

m:=nil;

//readln();

End.

Решение задачи Встреча автомобилей

 

Выберем координатную систему так, чтобы горизонтальная ось совпадала с дорогой, по которой движется первый автомобиль, а вертикальная была перпендикулярна горизонтальной. Основной подводный камень задачи состоит в том, что нам дан угол между направлениями движения, а не между дорогами, поэтому если скорости автомобилей имеют разные знаки, то угол между дорогами будет 180° - A.

Найдём зависимость координат каждого автомобиля от времени, выразим через них зависимость расстояния между ними от времени и найдём момент времени, в который это расстояние будет наименьшим. Координаты автомобилей:

x1 = S1+V1 t
y1 = 0
x2 = (S2+V2 t) cos b
y2 = (S2+V2 t) sin b,

где b - угол между дорогами. Поскольку расстояние - величина положительная, то вместо него можно минимизировать его квадрат:

r2(t) = (V
 
 
+V
 
 
- 2V1V2 cos b)t2 + 2 (S1V1+S2V2 - (S1V2+S2V1) cos b) t + S
 
 
+S
 
 
- 2S1S2 cos b
       

Момент времени, в который расстояние между автомобилями будет минимально, можно найти как вершину параболы: t = -b/2a, где a и b - коэффициенты при t2 и t соответственно. Область определения функции r2(t) - множество неотрицательных целых чисел, поэтому если t < 0, то минимумом r2(t) будет r(0).

Второй подводный камень заключается в вычислении угла между направлениями движения когда одна из скоростей равна нулю. Строго математически, угол между нулевым вектором и каким-либо другим есть величина неопределённая, но мы имеем дело с приближённой физической моделью, поэтому углом между дорогами можно считать как угол A, так и угол 180° - A - нужно найти минимальное расстояние в обоих случаях и выбрать меньшее из них.

 

Program Cars;

Type Real = Extended; { На всякий случай }

Var V1,V2,S1,S2,A: Real;

 

Function Solve(A: Real): Real; { Решение для угла A между дорогами }

Var CosA,R,ParA,ParB,ParC,T: Real;

Begin

If V1 * V2 < 0

Then A:= 180 - A;

CosA:= Cos(Pi * A / 180);

{ Коэффициеты квадратного уравнения }

ParA:= Sqr(V1) + Sqr(V2) - 2 * V1 * V2 * CosA;

ParB:= S1 * V1 + S2 * V2 - (S1 * V2 + S2 * V1) * CosA;

ParB:= ParB * 2;

ParC:= Sqr(S1) + Sqr(S2) - 2 * S1 * S2 * CosA;

T:= -ParB / (2 * ParA);

If T < 0

Then R:= Sqr(S1) + Sqr(S2) - 2 * S1 * S2 * CosA

Else R:= Sqr(T) * ParA + T * ParB + ParC;

Solve:= Sqrt(R);

End;

 

 

Var R,RR: Real;

 

BEGIN {

Assign(Input,'cars.in'); Reset(Input);

Assign(Output,'cars.out'); ReWrite(Output);}

Read (A,V1,V2,S1,S2);

R:= Solve(A);

If (V1 = 0) Or (V2 = 0)




<== предыдущая лекция | следующая лекция ==>
Задача № 47 | Правила представление лошади на выводке

Дата добавления: 2015-03-11; просмотров: 408. Нарушение авторских прав; Мы поможем в написании вашей работы!




Аальтернативная стоимость. Кривая производственных возможностей В экономике Буридании есть 100 ед. труда с производительностью 4 м ткани или 2 кг мяса...


Вычисление основной дактилоскопической формулы Вычислением основной дактоформулы обычно занимается следователь. Для этого все десять пальцев разбиваются на пять пар...


Расчетные и графические задания Равновесный объем - это объем, определяемый равенством спроса и предложения...


Кардиналистский и ординалистский подходы Кардиналистский (количественный подход) к анализу полезности основан на представлении о возможности измерения различных благ в условных единицах полезности...

РЕВМАТИЧЕСКИЕ БОЛЕЗНИ Ревматические болезни(или диффузные болезни соединительно ткани(ДБСТ))— это группа заболеваний, характеризующихся первичным системным поражением соединительной ткани в связи с нарушением иммунного гомеостаза...

Решение Постоянные издержки (FC) не зависят от изменения объёма производства, существуют постоянно...

ТРАНСПОРТНАЯ ИММОБИЛИЗАЦИЯ   Под транспортной иммобилизацией понимают мероприятия, направленные на обеспечение покоя в поврежденном участке тела и близлежащих к нему суставах на период перевозки пострадавшего в лечебное учреждение...

ТЕХНИКА ПОСЕВА, МЕТОДЫ ВЫДЕЛЕНИЯ ЧИСТЫХ КУЛЬТУР И КУЛЬТУРАЛЬНЫЕ СВОЙСТВА МИКРООРГАНИЗМОВ. ОПРЕДЕЛЕНИЕ КОЛИЧЕСТВА БАКТЕРИЙ Цель занятия. Освоить технику посева микроорганизмов на плотные и жидкие питательные среды и методы выделения чис­тых бактериальных культур. Ознакомить студентов с основными культуральными характеристиками микроорганизмов и методами определения...

САНИТАРНО-МИКРОБИОЛОГИЧЕСКОЕ ИССЛЕДОВАНИЕ ВОДЫ, ВОЗДУХА И ПОЧВЫ Цель занятия.Ознакомить студентов с основными методами и показателями...

Меры безопасности при обращении с оружием и боеприпасами 64. Получение (сдача) оружия и боеприпасов для проведения стрельб осуществляется в установленном порядке[1]. 65. Безопасность при проведении стрельб обеспечивается...

Studopedia.info - Студопедия - 2014-2025 год . (0.015 сек.) русская версия | украинская версия