Форум программистов, компьютерный форум, киберфорум
Pascal ABC
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
0 / 0 / 0
Регистрация: 28.02.2022
Сообщений: 1

Заменить линейные вычисления циклическими

01.06.2023, 18:00. Показов 553. Ответов 2
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Имеется код на паскале. Как переделать код чтобы вместо кучи формул подсчета температуры был цикл?
Pascal
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
var
T1,T2,T3,T4,T5,T6,T7,T8,T9,T10,T11,T12,T13,T14,T15,T16,T17,T18,T19,T20,Tf,Fizl,F,h,lam,sig,eps,del,L1,L2,L3,c,m,p,v,count: Real;
i:integer;
begin
T1:=277; T2:=277; T3:=277; T4:=277; T5:=277; T6:=277; T7:=277; T8:=277; T19:=277; T10:=277; T11:=277; T12:=277; T13:=277; T14:=277; T15:=277; T17:=277; T8:=277; T19:=277; T20:=277; Tf:=283;
del:=0.001;
sig:=0.0000000567;
eps:=0.9;
L1:=0.02;
L2:=0.0004;
L3:=0.1;
F:=L1*L2;
Fizl:=L3*del;
h:=0.001;
lam:=196;
c:=900;
p:=2700;
v:=L1*L2*L3;
m:=p*v;
count:=0;
for i:=1 to 10000 do
begin
T1:=T1+h*(((lam*F)/((c*m)*(del/2)))*(Tf-T1)+((lam*F)/((c*m)*(del)))*(T2-T1)-(eps*sig*(T1*T1*T1)*Fizl)/(c*m));
T2:=T2+h*(((lam*F)/((c*m)*(del)))*(T1-T2)+((lam*F)/((c*m)*(del)))*(T3-T2)-(eps*sig*(T2*T2*T2)*Fizl)/(c*m));
T3:=T3+h*(((lam*F)/((c*m)*(del)))*(T2-T3)+((lam*F)/((c*m)*(del)))*(T4-T3)-(eps*sig*(T3*T3*T3)*Fizl)/(c*m));
T4:=T4+h*(((lam*F)/((c*m)*(del)))*(T3-T4)+((lam*F)/((c*m)*(del)))*(T5-T4)-(eps*sig*(T4*T4*T4)*Fizl)/(c*m));
T5:=T5+h*(((lam*F)/((c*m)*(del)))*(T4-T5)+((lam*F)/((c*m)*(del)))*(T6-T5)-(eps*sig*(T5*T5*T5)*Fizl)/(c*m));
T6:=T6+h*(((lam*F)/((c*m)*(del)))*(T5-T6)+((lam*F)/((c*m)*(del)))*(T6-T5)-(eps*sig*(T6*T6*T6)*Fizl)/(c*m));
T7:=T7+h*(((lam*F)/((c*m)*(del)))*(T6-T7)+((lam*F)/((c*m)*(del)))*(T8-T7)-(eps*sig*(T7*T7*T7)*Fizl)/(c*m));
T8:=T8+h*(((lam*F)/((c*m)*(del)))*(T7-T8)+((lam*F)/((c*m)*(del)))*(T9-T8)-(eps*sig*(T8*T8*T8)*Fizl)/(c*m));
T9:=T9+h*(((lam*F)/((c*m)*(del)))*(T8-T9)+((lam*F)/((c*m)*(del)))*(T10-T9)-(eps*sig*(T9*T9*T9)*Fizl)/(c*m));
T10:=T1+h*(((lam*F)/((c*m)*(del)))*(T9-T10)+((lam*F)/((c*m)*(del)))*(T11-T10)-(eps*sig*(T10*T1*T1)*Fizl)/(c*m));
T11:=T11+h*(((lam*F)/((c*m)*(del)))*(T10-T11)+((lam*F)/((c*m)*(del)))*(T12-T11)-(eps*sig*(T11*T11*T11)*Fizl)/(c*m));
T12:=T12+h*(((lam*F)/((c*m)*(del)))*(T11-T12)+((lam*F)/((c*m)*(del)))*(T13-T12)-(eps*sig*(T12*T12*T12)*Fizl)/(c*m));
T13:=T13+h*(((lam*F)/((c*m)*(del)))*(T12-T13)+((lam*F)/((c*m)*(del)))*(T14-T13)-(eps*sig*(T13*T13*T13)*Fizl)/(c*m));
T14:=T14+h*(((lam*F)/((c*m)*(del)))*(T13-T14)+((lam*F)/((c*m)*(del)))*(T15-T14)-(eps*sig*(T14*T14*T14)*Fizl)/(c*m));
T15:=T15+h*(((lam*F)/((c*m)*(del)))*(T4-T15)+((lam*F)/((c*m)*(del)))*(T16-T15)-(eps*sig*(T15*T15*T15)*Fizl)/(c*m));
T16:=T16+h*(((lam*F)/((c*m)*(del)))*(T15-T16)+((lam*F)/((c*m)*(del)))*(T17-T16)-(eps*sig*(T16*T16*T16)*Fizl)/(c*m));
T17:=T17+h*(((lam*F)/((c*m)*(del)))*(T6-T17)+((lam*F)/((c*m)*(del)))*(T18-T17)-(eps*sig*(T17*T17*T1)*Fizl)/(c*m));
T18:=T18+h*(((lam*F)/((c*m)*(del)))*(T17-T18)+((lam*F)/((c*m)*(del)))*(T19-T18)-(eps*sig*(T18*T18*T18)*Fizl)/(c*m));
T19:=T19+h*(((lam*F)/((c*m)*(del)))*(T18-T19)+((lam*F)/((c*m)*(del)))*(T20-T19)-(eps*sig*(T19*T19*T19)*Fizl)/(c*m));
T20:=T20+h*(((lam*F)/((c*m)*(del)))*(T19-T20)+((lam*F)/((c*m)*(del/2)))*(Tf-T20)- (eps*sig*(T2*T2*T2)*Fizl)/(c*m));
Count:=count+1;
if (count=1)  or (count=1000) or (count=2000) or (count=3000) or (count=4000) or (count=5000) or (count=6000) or (count=7000) or (count=9000) or (count=9000) or (count=10000) then
Writeln('|',T1:2:4);
Writeln('|',T2:2:4);
Writeln('|',T3:2:4);
Writeln('|',T4:2:4);
Writeln('|',T5:2:4);
Writeln('|',T6:2:4);
Writeln('|',T7:2:4);
Writeln('|',T8:2:4);
Writeln('|',T9:2:4);
Writeln('|',T10:2:4);
Writeln('|',T11:2:4);
Writeln('|',T12:2:4);
Writeln('|',T13:2:4);
Writeln('|',T14:2:4);
Writeln('|',T15:2:4);
Writeln('|',T16:2:4);
Writeln('|',T17:2:4);
Writeln('|',T18:2:4);
Writeln('|',T19:2:4);
Writeln('|',T20:2:4);
end;
end.
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
01.06.2023, 18:00
Ответы с готовыми решениями:

Линейные вычисления 2
Вычислить заданное выражение при указанных переменных значениях. Входные данные задать самостоятельно. В программе предусмотреть вывод...

Линейные вычисления 3
Вычислить заданное выражение при указанных переменных. Введите неизвестные данные с клавиатуры по своему выбору. В программе предусмотреть...

Линейные вычисления
Вычислить заданное выражение при указанных переменных значениях. Входные данные задать самостоятельно. В программе предусмотреть вывод...

2
Модератор
10445 / 5737 / 3406
Регистрация: 17.08.2012
Сообщений: 17,449
02.06.2023, 19:34
Объявить T как массив (возможно, разместить в этом же массиве Tf), и вычислять элементы этого массива в цикле. Это так, навскидку.

А не навскидку... Написано много, путанно, и, возможно, неверно. Разбираться в этом смысл умер. Тем более, смысл умер гадать, что эта программа должна вообще делать.

Задание выложите. А то я свой хрустальный шар на днях отдал на профилактику.

И ещё.
Темы называйте осмысленно, вопрос пишите полностью.
На будущее: фотографии текста запрещены. Фотографии формул выкладывать можно, но без обрамляющего текста.
Вы при регистрации на форуме обещали соблюдать правила форума. Пожалуйста, выполняйте Ваше обещание. Ссылка на правила есть на любой странице форума.
0
1 / 1 / 0
Регистрация: 22.03.2019
Сообщений: 4
07.06.2023, 19:18
Задать Т как массив, где Т1..Т20 - будут под соответствующими индексами, а Tf под 0 и 21 индексами

После все параметры задаются, и доходим до формул, ее редактим под массив и получаем на выходе:

Pascal
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
const
   n = 20;
var
   T: array[0..n+1] of real;
   Fizl,F,h,lam,sig,eps,del,L1,L2,L3,c,m,p,v:real;
   i,j:integer;
begin
    for i := 1 to n do
        T[i]:=277;
   T[0]:=283;
   T[n+1]:=283;
 
   del:=0.001;
   sig:=0.0000000567;
   eps:=0.9;
   L1:=0.02;
   L2:=0.0004;
   L3:=0.1;
   F:=L1*L2;
   Fizl:=L3*del;
   h:=0.001;
   lam:=196;
   c:=900;
   p:=2700;
   v:=L1*L2*L3;
   m:=p*v;
 
   for j:=1 to 1000 do
        begin
            for i:=1 to n do
                begin
                    T[i]:=T[i]+h*(((lam*F)/((c*m)*(del/2)))*(T[i-1]-T[i])+((lam*F)/((c*m)*(del)))*(T[i+1]-T[i])-(eps*sig*(T[i]*T[i]*T[i])*Fizl)/(c*m));
                    if (j mod 1000 = 0) or (j=1) then
                        Writeln('|',T[i]:2:4);
                end;
            if (j mod 1000 = 0) or (j=1) then
                writeln;
        end;
end.
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
07.06.2023, 19:18
Помогаю со студенческими работами здесь

Линейные вычисления
Вычислить заданные выражения. Входные данные задать самостоятельно, вывести результаты вычислений на экран. t * 1 = 1/(6a ^ 3) *...

линейные программы вычисления на языке JavaScript
Доброго всем времени суток! помогите пожалуйста разобраться в теме линейные программы вычисления на языке JavaScript. Я не могу понять как...

Линейные алгоритмы: вычисления по формулам сложного радикала
Для различных a и b выполните вычисления по формулам сложного радикала: . Сравните вычисления соответствующих левых и правых частей...

Динамические структуры данных, линейные списки: заменить фамилию заданного студента
Используя технологию структурного программирования разработать программу обработки односвязных линейных списков студентов с числом...

Работа с циклическими конструкциями.
Пожалуйста, помогите написать две задачки (Pascal Free)


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
Переходник USB-CAN-GPIO
Eddy_Em 20.03.2026
Достаточно давно на работе возникла необходимость в переходнике CAN-USB с гальваноразвязкой, оный и был разработан. Однако, все меня терзала совесть, что аж 48-ногий МК используется так тупо: просто. . .
Оттенки серого
Argus19 18.03.2026
Оттенки серого Нашёл в интернете 3 прекрасных модуля: Модуль класса открытия диалога открытия/ сохранения файла на Win32 API; Модуль класса быстрого перекодирования цветного изображения в оттенки. . .
SDL3 для Desktop (MinGW): Рисуем цветные прямоугольники с помощью рисовальщика SDL3 на Си и C++
8Observer8 17.03.2026
Содержание блога Финальные проекты на Си и на C++: finish-rectangles-sdl3-c. zip finish-rectangles-sdl3-cpp. zip
Символические и жёсткие ссылки в Linux.
algri14 15.03.2026
Существует два типа ссылок — символические и жёсткие. Ссылка в Linux — это запись в каталоге, которая может указывать либо на inode «файла-ИСТОЧНИКА», тогда это будет «жёсткая ссылка» (hard link),. . .
[Owen Logic] Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора
ФедосеевПавел 14.03.2026
Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора ВВЕДЕНИЕ Выполняя задание на управление насосной группой заполнения резервуара,. . .
делаю науч статью по влиянию грибов на сукцессию
anaschu 13.03.2026
прикрепляю статью
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru