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

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

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

> Задача с циклом
Гость_Антон
сообщение 2.11.2004 16:10
Сообщение #1


Гость






Помогите пожалуйста с решением задач (желательно с объяснением).

Задача 2.

Ученикам 1-го класса назначается дополнительный стакан молока (200мл.), если их вес составляет меньше 30кг. Определить, сколько литров молока потребуется ежедневно для одного класса, состоящего из n учеников. После взвешивания вес каждого ученика вводится в ЭВМ.

Задача 1.

Траектория снаряда, вылетающего из орудия под углом a с начальной скоростью V0 описывается уравнением
x=V0*cos a*t
y=V0*sin at-g*t2/2, где g=9.8 м/c2 - ускорение свободного падения, t - время. Вводя n заданных пар V0,а, определить сколько снарядов поразят цель высотой Р, расположенную в вертикальной плоскости ствола орудия на расстоянии R на высоте Н.
 К началу страницы 
+ Ответить 
 
 Ответить  Открыть новую тему 
Ответов
volvo
сообщение 2.11.2004 16:48
Сообщение #2


Гость






Алгоритм будет таким (на работоспособность пока не проверял):

Код

const
 G = 9.8;
 n = 5;

 r = 2500; { метры }
 h = 200;  { метры }
 p = 30;   { метры }

var
 v0, a, x, y: real;
 hit, i, t: integer;
begin
 hit := 0;
 for i := 1 to n do
   begin
     write( 'v0 (в м/секунду) = ' ); readln(v0);
     write( 'a (в градусах) = ' ); readln(a);

     t := 1;
     repeat
       x := v0 * cos(a / (180/Pi)) * t;
       y := v0 * sin(a / (180/Pi)) * t - (G * sqr(t)/2);

       if (x >= r) and ((y > h) and (y < (h + p))) then
         begin
           hit := hit + 1; break;
         end;
       t := t + 1;
     until y <= 0;
   end;

 writeln( hit, ' попаданий' );
end.


Сообщение отредактировано: volvo - 9.11.2004 19:59
 К началу страницы 
+ Ответить 

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


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

 



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