Смекни!
smekni.com

Використання мови програмування Turbo Pascal при розв’язуванні задач з фізики (стр. 1 из 2)

Дуже часто в учнів і студентів виникає потреба швидко розв’язати ті чи інші задачі з фізики. Це може бути зумовлено браком часу, великим об’ємом роботи, яку необхідно виконати тощо. Дуже часто їм доводиться виконувати кілька однотипних задач, які відрізняються лише значенням величин, які дано за умовою задачі. В такому випадку можна обійтися без розв’язування кожної задачі окремо. Велику допомогу учневі чи студенту при цьому може надати вміння програмувати мовою програмування Pascal. Необхідно мати персональний комп’ютер чи ноутбук і середовище програмування Turbo Pascal. Написані програми дозволять миттєво розв’язувати задачі певного типу. Найголовніше – попередньо розв’язати хоча б одну задачу цього типу письмово для того, щоб був зразок, по якому надалі можна писати програми. Отже, нижче будуть наведені приклади написання програм мовою Turbo Pascal для швидкого розрахунку тих чи інших фізичних величин.

фізичний тіло програмування pascal


1. Задача на знаходження швидкості фізичного тіла, якщо відомо шлях і час

var v,s, t: real;

begin

writeln ('Введіть відстань (в метрах) і час (в секундах)');

readln (s,t);

v:=s/t;

writeln ('Швидкість тіла = ', v, ' м/с');

end.

Якщо необхідно знайти час, якщо відомо відстань і швидкість, то в даній програмі змінюємо наступні рядки:

writeln ('Введіть відстань (в метрах) і час (в секундах)');

readln (s,t);

v:=s/t;

writeln ('Швидкість тіла = ', v, ' м/с');

на writeln ('Введіть відстань (в метрах) і швидкість (в метрах за секунду)');

readln (s,v);

t:=s/v;

writeln ('Час руху тіла = ', v, ' с');

2. Задача на знаходження швидкості двох фізичних тіл одне відносно одного, якщо вони рухаються вздовж однієї лінії:

var v1,v2,v: real;

begin

writeln ('Введіть швидкість першого і другого тіла (в метрах за секунду). Якщо тіла рухаються в протилежних напрямках, одне зі значень швидкості введіть зі знаком «мінус»);

readln (v1,v2);

v:=v1+v2;

writeln ('Швидкість тіл одне відносно одного = ', v, ' м/с');

end.

3. Задача на знаходження шляху, що проходить фізичне тіло за певний час, рухаючись з прискоренням і початковою швидкістю (тіло, кинуте з деякої висоти):

var s ,v0, t: real;

const g=9.81;

begin

writeln ('Введіть початкову швидкість (в метрах за секунду) і час (в секундах)');

readln (v0, t);

s:=v0*t+(g*sqr(t)/2);

writeln ('Шлях = ', s, ' м');

end.

4. Задача на знаходження періоду та частоти коливань за циклічною частотою.

var w,T,v: real;

const Pi=3.14;

begin

writeln ('Введіть значення циклічної частоти обертання матеріальної точки навколо осі (в секундах)');

readln (w);

T:=2*Pi/w;

v:=1/T;

writeln ('період обертання матеріальної точки = ', T, ' с', ‘частота обертання матеріальної точки = ’, v, ‘ Гц’);

end.

5. Задача на знаходження доцентрового прискорення за радіусом і лінійною швидкістю обертання матеріальної точки навколо осі:

var a,r,v: real;

begin

writeln ('Введіть значення швидкості обертання точки (в м/с) і радіуса (в м)');

readln (v,r);

a:=sqr(v)/r;

writeln ('доцентрове прискорення точки = ’, a, ‘м/сек.в кв.’);

end.

6. Задача на знаходження кінетичної енергії тіла відомої маси, що рухається з відомою швидкістю:

var E,m,v: real;

begin

writeln ('Введіть значення швидкості тіла (в м/с) і його маси (в кг)');

readln (v,m);

E:= m*sqr(v)/2;

writeln (‘кінетична енергія тіла = ’, E, ‘ Дж’);

end.


7. Задача на знаходження роботи сили по переміщенню тіла відомої маси на певну відстань:

var A,m,s: real;

begin

writeln ('Введіть масу тіла (в кг) і переміщення (в м)');

readln (m,s);

A:=m*9.81*s;

writeln (‘робота = ’, A, ‘ Дж’);

end.

8. Задача на знаходження роботи, необхідної для того, щоб змінити кінетичну енергію тіла відомої маси (його швидкість):

var A,m,v1,v2: real;

begin

writeln ('Введіть значення початкової та кінцевої швидкості тіла (в м/с) і його маси (в кг)');

readln (v1,v2,m);

A:= (m*sqr(v1)/2)-(m*sqr(v2)/2);

writeln (‘робота по зміні кінетичної енергії тіла = ’, A, ‘ Дж’);

end.

Від’ємне значення роботи буде вказувати на те, що для того, щоб змінити швидкість, треба збільшити кінетичну енергію тіла.

9. Задача на знаходження часу польоту тіла, кинутого під кутом до горизонту з відомою початковою швидкістю:

var alpha,t,v0: real;

const g=9.81;

begin

writeln (‘Введіть значення кута (в радіанах) і початкову швидкість (в м/с)');

readln (alpha,v0);

t:=v0*sin(alpha)/g;

writeln (‘ час = ’, t, ‘ с’);

end.

10. На штовхання ядра, кинутого під кутом alpha до горизонту, затрачена робота А. Через який час t і на якій відстані s від місця кидання ядро впаде на землю? Маса тіла m.

var alpha,t,A,m,s: real;

const g=9.81;

begin

writeln (‘Введіть значення кута (в радіанах), масу тіла (в кг), роботу (в Дж)');

readln (alpha,m,A);

t:=(2*sin(alpha)*sqrt(2*A))/(g*sqrt(m));

s:=t*cos(alpha)*sqrt(2*A/m);

writeln (‘ час = ’, t, ‘ с’, ‘ відстань = ’, s, ‘ м’);

end.

11. Задача на знаходження сили гравітаційної взаємодії між двома тілами відомої маси, які знаходяться на відомій відстані одне від одного:

var m1,m2,r,F: real;

const G=6.67E-11;

begin

writeln (‘Введіть масу першого і другого тіл (в кг) і відстань між ними (в м)');

readln (m1,m2,r);

F:=G*m1*m2/sqr(r);

writeln (‘F = ‘, F, ‘Н’);

end.

12. Обчислити гравітаційну сталу G, знаючи радіус земної кулі R, середню густину землі r і прискорення вільного падіння g на поверхні Землі:

var R,G,r1,g1: real;

begin

writeln (‘введіть радіус (в м), середню густину (в кг/куб.м) і прискорення вільного падіння (в Н/с)');

readln (R,r1,g1);

G:=(3*g1)/(4*3.14*R*r1);

writeln (‘G = ‘, G);

end.

13. Задача на знаходження моменту інерції Iта моменту імпульсу Lкулі масою m і радіусом r:

var I,L,m,r,T: real;

begin

writeln (‘введіть радіус (в м), масу (в кг) і період обертання (в с) кулі');

readln (r,m,T);

I:=0.4*m*sqr(r);

L:=I*2*3.14/T;

writeln (‘I = ‘, I, ‘ кг*кв.м’, ‘L = ’, L, ‘кг*кв.м/с’);

end.

14. Задача на знаходження енергії, необхідної для нагрівання тіла відомої маси, виготовленого з відомого матеріалу, на певну кількість градусів Цельсія чи Кельвіна:

var Q,c,m,t12: real;

begin

writeln (‘введіть питому теплоємність речовини (в Дж/кг*К), массу тіла і різницю температур');

readln (c,m,t12);

Q:=c*m*t12;

writeln (‘Q = ‘, Q, ‘ Дж’);

end.

15. За який часt кип’ятильник потужністю P нагріє воду масою m до температури кипіння від початкової температури t0?

var P,c,m,t,t0: real;

begin

writeln (‘введіть масу води (в кг), потужність (в Вт) та початкову температуру води (в градусах Цельсія)');

readln (m,P,t0);

t:=(4200*m*(100-t0))/P;

writeln (‘t = ‘, t, ‘ c’);

end.

16. Задача на знаходження сили взаємодії між двома зарядами, що знаходяться на певній відстані у вакуумі чи в повітрі:

var F,q1,q2,r: real;

const k=9E10;

begin

writeln (‘введіть модулі першого та другого зарядів (в Кл) та відстань між ними (в м)');

readln (q1,q2,r);

F:=k*q1*q2/sqr(r);

writeln (‘F = ‘, F, ‘ H’);

end.

17. Задача на знаходження величини напруженості, яку створює зарядq на відстані r від себе:

var E,q,r: real;

const k=9E10;

begin

writeln (‘введіть модуль заряду (в Кл) та відстань до даної точки (в м)');

readln (q,r);

E:=k*q/sqr(r);

writeln (‘E = ‘, E, ‘ В/м’);

end.

18. Задача на знаходження потенціалу, який створює даний заряд на деякій відстані від себе:

varf,q,r: real;

const k=9E10;

begin

writeln (‘введіть модуль заряду (в Кл) та відстань до даної точки (в м)');

readln (q,r);

f:=k*q/r;

writeln (‘ потенціал = ‘, f, ‘ В’);

end.

19. Задача на знаходження заряду конденсатора з відомою ємністю, що заряджений до певної напруги:

var c,q,u: real;

begin

writeln (‘введіть електроємність конденсатора (в Ф) та напругу на його обкладках (в В)');

readln (c,u);

q:=c*u;

writeln (‘ q = ‘, q, ‘ Кл’);

end.

20. Задача на знаходження енергії конденсатора відомої ємності, зарядженого до певної напруги:

varW,C,U: real;

begin

writeln (‘введіть електроємність конденсатора (в Ф) та напругу на його обкладках (в В)');

readln (C,U);

W:=C*sqr(U)/2;

writeln (‘ W = ‘, W, ‘ Дж’);

end.

21. Задача на знаходження часу розряду конденсатора ємністю С через резистором з опором R від напруги U1 до напруги U2:

var t,C,R, U1,U2: real;

begin

writeln (‘введіть електроємність конденсатора (в Ф) , опір резистора (в Ом), початкову та кінцеву напругу (в В)');

readln (C,R,U1,U2);

t:=C*R*ln(U1/U2);

writeln (‘ t = ‘, t, ‘ c’);

end.

22. Задача на знаходження електроємності конденсатора, якщо відомо площа обкладок S, відстань між ними d та відносна діелектрична проникливість діелектрика e:

var C,e,S,d: real;

const e0=8.85E-12;

begin

writeln (‘введіть площу пластин (в кв.м) , відстань між ними (в м) та відносну діелектричну проникливість діелектрика');

readln (S,d,e);

C:=e*e0*S/d;

writeln (‘ C = ‘, C, ‘ Ф’);

end.

23. Задача на знаходження електричного опору провідника при нагріванні до певної температури, якщо відомо його опір при 0 оС, температурний коефіцієнт опору та температуру, до якої він нагрівається:

var R,R0,t,x: real;

begin

writeln (‘введіть опір провідника при 0 градусів Цельсія (в Ом), температуру (в градусах Цельсія) та температурний коефіцієнт опору провідника‘);

readln (R0,t,x);

R:=R0*(1+x*t);

writeln (‘ R = ‘, R, ‘ Ом’);

end.

24. Задача на знаходження температури, до якої нагрівся провідник з відомим температурним коефіцієнтом опору, якщо відомо його опір при 0 оС та при даній температурі:

var R,R0,t,x: real;

begin

writeln (‘введіть опір провідника при 0 градусів Цельсія та при даній температурі (в Ом) та температурний коефіцієнт опору провідника‘);

readln (R0,R,x);

t:=((R/R0)-1)/x;

writeln (‘ t = ‘, t, ‘ градусів Цельсія’);

end.

25. Задача на знаходження сили струму в колі за законом Ома для ділянки кола:

var R,U,I: real;

begin

writeln (‘введіть опір (в Ом) та напругу (в В)‘);

readln (R, U);

I:=U/R;

writeln (‘ I = ‘, I, ‘ A’);

end.

26. Задача на знаходження сили струму в колі за законом Ома для повного кола:

var R,U,I,r1: real;

begin

writeln (‘введіть зовнішній опір та внутрішній опір джерела струму (в Ом) та електрорушійну силу (в В)‘);

readln (R,r1, U);

I:=U/(R+r1);

writeln (‘ I = ‘, I, ‘ A’);

end.

27. Задача на знаходження внутрішнього опору джерела струму:

var R,U,I,r1: real;

begin

writeln (‘введіть зовнішній опір (в Ом), силу струму в колі (в А) та електрорушійну силу (в В)‘);

readln (R,I,U);

r1:=(U/I)-R;

writeln (‘ r = ‘, r1, ‘ Ом’);

end.

28. Задача на знаходження роботи, яку виконує електричний струм, якщо відомо час, силу струму і опір провідника: