49727 (Алгоритмизация и программирование разветвляющихся процессов)

2016-07-30СтудИзба

Описание файла

Документ из архива "Алгоритмизация и программирование разветвляющихся процессов", который расположен в категории "". Всё это находится в предмете "информатика" из 1 семестр, которые можно найти в файловом архиве . Не смотря на прямую связь этого архива с , его также можно найти и в других разделах. Архив можно найти в разделе "курсовые/домашние работы", в предмете "информатика, программирование" в общих файлах.

Онлайн просмотр документа "49727"

Текст из документа "49727"

Министерство Образования Республики Беларусь

Белорусский национальный технический университет

Кафедра: «Машины и технологии литейного производства»

Курсовой проект

на тему:

  1. «Алгоритмизация и программирование разветвляющихся процессов»

  2. «Методы решения нелинейных уравнений»

Минск 2010г.

Постановка задачи №1. Разработать алгоритм и программу для вычисления функции Z(x), заданной интервально на различных промежутках. Если функция Z(x) неопределенна при каких-либо значениях x, то в программе необходимо предусмотреть вывод сообщения “При данном X функция неопределенна” и вывести значение X. Общий вид задания функции:

где ,

,

,

,

Значения a,b,c,d вычисляются по формулам:

, ,

, , где n – номер варианта.

Листинг программы №1

Program kursovoj_Braginec_DA;

var j:integer;

a,b,c,d,x,x4,x7,x11,x15,x25:real;

i,n:integer;

z:extended;

Begin

a:=0;b:=0;c:=0;n:=3;

for j:=1 to n+3 do begin

a:=a+sin(j); c:=c+j*j*j+j; end;

for j:=2 to n+3 do begin

b:=b+1/ln(j);end; d:=a+b+c;

x4:=5*4-80;x7:=5*7-80; x11:=5*11-80; x15:=5*15-80; x25:=5*25-80;

writeln('Vvedite znachenie x=');

readln(x);

if x<=x4 then begin

if (x>1) and (a>1) then begin

z:=b*SQRT(x)+SQRT(ln(a*x))+c*x*x*x+d*exp((1/10)*ln(x));

writeln('x=',x:6:2,' Z=',z:12:3);

end

else writeln('x=',x:6:2,' Z=net znacheniy');

end;

if (x4

if (x>0) then begin

z:=a*exp(3*ln(cos(ABS(x))))+b*sin(d*x)+exp(4*(sin(x)/cos(x)))+d*ln(x)*ln(x);

writeln('x=',x:6:2,' Z=',z:12:3);end else

writeln('x=',x:6:2,' Z=net znacheniy');

end;

if (x7

if (x>0) and (x/d>=0) then begin

z:=ln(abs(a*x))+b*cos(x*x*x*x)*sin(1/(x*x*x))-c*ln(x)*ln(x)*ln(x)+sqrt(x/d);

writeln('x=',x:6:2,' Z=',z:12:3);;

end

else writeln('x=',x:6:2,' Z=net znacheniy');

end;

if (x11

if (x-5*x*x*x>0) and (d>0) and (x*x*x-2*d<>0) and (exp(3*ln(x+c))>=0) then begin

z:=a*exp(-4*x)+b*ln(x-5*x*x*x)+c*SQRT(exp(3*ln(x+c)))+ln(d)/(x*x*x-2*d);

writeln('x=',x:6:2,' Z=',z:12:3);;

end

else writeln('x=',x:6:2,' Z=net znacheniy');

end;

if (x15

if (x<>0) and (x-d>0) and (d>=0) then begin

z:=a*exp(3/8*ln(ln(ABS(x))))+b*sin(b*exp(-b/x))+(x-c)+d*sin(x*x*x)*sin(x*x*x)/(cos(x*x*x)*cos(x*x*x)*ln(x-d));

writeln('x=',x:6:2,' Z=',z:12:3);

end

else

writeln('x=',x:6:2,' Z=net znacheniy');

end;

if x>x25 then begin

z:=0;

writeln('x=',x:6:2,' Z=',z:12:3);end;

End.

Результаты задачи №1

Vvedite znachenie x=23

x= 23.00 Z=net znacheniy

Vvedite znachenie x=-37

x=-37.00 Z=net znacheniy

Vvedite znachenie x=-100

x=-100.00 Z=net znacheniy

Vvedite znachenie x=-7

x= -7.00 Z=-149327123808.531

Постановка задачи 2. Разработать алгоритм и программу формирования одномерного массива A[i] по условию A[i]=Z(x), заданной интервально на различных промежутках. Если функция Z(x) неопределенна при каких-либо значениях x, то в программе необходимо предусмотреть вывод сообщения «При данном Х функция неопределенна» и вывести значение Х. Вид задания функции:

где ,

,

,

,

Значения a,b,c,d вычисляются по формулам:

, ,

, , где n – номер варианта.

При формировании функции массива A[i] можно выбрать несколько вариантов шага, но при условии, чтобы на каждом из интервалов было взято не менее 10-ти значений

При выполнении задачи шаг по x можно брать нецелым числом. В программе необходимо организовать вывод всех элементов A[i] и числа их значений на монитор.

Блок-схема для задачи №2.

Листинг программы №2

Program Kursovoj_Braginec_DA;

uses crt;

var j:integer;

a,b,c,d,x4,x7,x11,x15,x25:real;

i,n,x:integer;

f:text;

z:extended;

Begin

clrscr;

assign(f,'Otvet.txt');

rewrite(f);

a:=0;b:=0;c:=0;n:=3;

for j:=1 to n+3 do begin

a:=a+sin(j); c:=c+j*j*j+j; end;

for j:=2 to n+3 do begin

b:=b+1/ln(j);end; d:=a+b+c;

x4:=5*4-80;x7:=5*7-80; x11:=5*11-80; x15:=5*15-80; x25:=5*25-80;x:=-80; for i:=1 to 131 do begin

if x<=x4 then begin

if (x>1) and (a>1) then begin

z:=b*SQRT(x)+SQRT(ln(a*x))+c*x*x*x+d*exp((1/10)*ln(x));

writeln(f,'x=',x:6,' A[',i,']=',z:6:3);

end

else writeln(f,'x=',x:6,' A[',i,']=net znacheniy');

end;

if (x4

if (x>0) then begin

z:=a*exp(3*ln(cos(ABS(x))))+b*sin(d*x)+exp(4*(sin(x)/cos(x)))+d*ln(x)*ln(x);

writeln(f,'x=',x:6,' A[',i,']=',z:6:3);end else

writeln(f,'x=',x:6,' A[',i,']=net znacheniy');

end;

if (x7

if (x>0) and (x/d>=0) then begin

z:=ln(abs(a*x))+b*cos(x*x*x*x)*sin(1/(x*x*x))-c*ln(x)*ln(x)*ln(x)+sqrt(x/d);

writeln(f,'x=',x:6,' A[',i,']=',z:6:3); end

else

writeln(f,'x=',x:6,' A[',i,']=net znacheniy');

end;

if (x11

if (x-5*x*x*x>0) and (d>0) and (x*x*x-2*d<>0) and (exp(3*ln(x+c))>=0) then begin

z:=a*exp(-4*x)+b*ln(x-5*x*x*x)+c*SQRT(exp(3*ln(x+c)))+ln(d)/(x*x*x-2*d);

writeln(f,'x=',x:6,' A[',i,']=',z:6:3);

end

else

writeln(f,'x=',x:6,' A[',i,']=net znacheniy');

end;

if (x15

if (x<>0) and (x-d>0) and (d>=0) then begin

z:=a*exp(3/8*ln(ln(ABS(x))))+b*sin(b*exp(-b/x))+(x-c)+d*sin(x*x*x)*sin(x*x*x)/(cos(x*x*x)*cos(x*x*x)*ln(x-d));

writeln(f,'x=',x:6,' A[',i,']=',z:6:3);

end

else

writeln(f,'x=',x:6,' A[',i,']=net znacheniy');

end;

if x>x25 then begin

z:=0;

writeln(f,'x=',x:6,' A[',i,']=',z:6:3);end;

x:=x+1;

end;

End.

Результаты задачи №2.

x= -80 A[1]=net znacheniy

x= -79 A[2]=net znacheniy

x= -78 A[3]=net znacheniy

x= -77 A[4]=net znacheniy

x= -76 A[5]=net znacheniy

x= -75 A[6]=net znacheniy

x= -74 A[7]=net znacheniy

x= -73 A[8]=net znacheniy

x= -72 A[9]=net znacheniy

x= -71 A[10]=net znacheniy

x= -70 A[11]=net znacheniy

x= -69 A[12]=net znacheniy

x= -68 A[13]=net znacheniy

x= -67 A[14]=net znacheniy

x= -66 A[15]=net znacheniy

x= -65 A[16]=net znacheniy

x= -64 A[17]=net znacheniy

x= -63 A[18]=net znacheniy

x= -62 A[19]=net znacheniy

x= -61 A[20]=net znacheniy

x= -60 A[21]=net znacheniy

x= -59 A[22]=net znacheniy

x= -58 A[23]=net znacheniy

x= -57 A[24]=net znacheniy

x= -56 A[25]=net znacheniy

x= -55 A[26]=net znacheniy

x= -54 A[27]=net znacheniy

x= -53 A[28]=net znacheniy

x= -52 A[29]=net znacheniy

x= -51 A[30]=net znacheniy

x= -50 A[31]=net znacheniy

x= -49 A[32]=net znacheniy

x= -48 A[33]=net znacheniy

x= -47 A[34]=net znacheniy

x= -46 A[35]=net znacheniy

x= -45 A[36]=net znacheniy

x= -44 A[37]=net znacheniy

x= -43 A[38]=net znacheniy

x= -42 A[39]=net znacheniy

x= -41 A[40]=net znacheniy

x= -40 A[41]=net znacheniy

x= -39 A[42]=net znacheniy

x= -38 A[43]=net znacheniy

x= -37 A[44]=net znacheniy

x= -36 A[45]=net znacheniy

x= -35 A[46]=net znacheniy

x= -34 A[47]=net znacheniy

x= -33 A[48]=net znacheniy

x= -32 A[49]=net znacheniy

x= -31 A[50]=net znacheniy

x= -30 A[51]=net znacheniy

x= -29 A[52]=net znacheniy

x= -28 A[53]=net znacheniy

x= -27 A[54]=net znacheniy

x= -26 A[55]=net znacheniy

x= -25 A[56]=net znacheniy

x= -24 A[57]=-5.08366015838512507E+0040

x= -23 A[58]=net znacheniy

x= -22 A[59]=net znacheniy

x= -21 A[60]=net znacheniy

x= -20 A[61]=net znacheniy

x= -19 A[62]=net znacheniy

x= -18 A[63]=-1919150107529503510000000000000.000

x= -17 A[64]=-35150460342785758200000000000.000

x= -16 A[65]=-643803138411235418000000000.000

x= -15 A[66]=-11791665798573937500000000.000

x= -14 A[67]=-215971892663317589000000.000

x= -13 A[68]=-3955663196137779530000.000

x= -12 A[69]=-72450498665911326200.000

x= -11 A[70]=-1326977170869205140.000

x= -10 A[71]=-24304434670875825.700

x= -9 A[72]=-445151244453472.912

x= -8 A[73]=-8153225056674.438

x= -7 A[74]=-149327123808.531

x= -6 A[75]=-2730605050.098

x= -5 A[76]=-45581616.828

x= -4 A[77]=net znacheniy

x= -3 A[78]=net znacheniy

x= -2 A[79]=net znacheniy

x= -1 A[80]=net znacheniy

x= 0 A[81]=net znacheniy

x= 1 A[82]=net znacheniy

x= 2 A[83]=net znacheniy

x= 3 A[84]=net znacheniy

x= 4 A[85]=net znacheniy

x= 5 A[86]=net znacheniy

x= 6 A[87]=net znacheniy

x= 7 A[88]=net znacheniy

x= 8 A[89]=net znacheniy

x= 9 A[90]=net znacheniy

x= 10 A[91]=net znacheniy

x= 11 A[92]=net znacheniy

x= 12 A[93]=net znacheniy

x= 13 A[94]=net znacheniy

x= 14 A[95]=net znacheniy

x= 15 A[96]=net znacheniy

x= 16 A[97]=net znacheniy

x= 17 A[98]=net znacheniy

x= 18 A[99]=net znacheniy

x= 19 A[100]=net znacheniy

x= 20 A[101]=net znacheniy

x= 21 A[102]=net znacheniy

x= 22 A[103]=net znacheniy

x= 23 A[104]=net znacheniy

x= 24 A[105]=net znacheniy

x= 25 A[106]=net znacheniy

x= 26 A[107]=net znacheniy

x= 27 A[108]=net znacheniy

x= 28 A[109]=net znacheniy

x= 29 A[110]=net znacheniy

x= 30 A[111]=net znacheniy

x= 31 A[112]=net znacheniy

x= 32 A[113]=net znacheniy

x= 33 A[114]=net znacheniy

x= 34 A[115]=net znacheniy

x= 35 A[116]=net znacheniy

x= 36 A[117]=net znacheniy

x= 37 A[118]=net znacheniy

x= 38 A[119]=net znacheniy

x= 39 A[120]=net znacheniy

x= 40 A[121]=net znacheniy

x= 41 A[122]=net znacheniy

x= 42 A[123]=net znacheniy

x= 43 A[124]=net znacheniy

x= 44 A[125]=net znacheniy

x= 45 A[126]=net znacheniy


Постановка задачи №3.

Разработать алгоритм и программу для решения нелинейного уравнения с параметрами методом половинного деления. С помощью программы вычислить все корни уравнений в соответствии с указанным вариантом и заданной точностью ε=10-4. Параметр а задать самостоятельно методом перебора. Определить для каких а уравнение имеет 1,2,3,4,5 действительных корней.

3

Построить таблицу которая должна иллюстрировать количество корней уравнения для F(x,a)=0 (ограничиться 5-тью корнями при заданном). Построить график F(x,a) от x для параметров a соответствующего наибольшему количеству корней найденных в задании.

Листинг программы №3.

Program Kursovoj_Braginec_DA;

uses crt;

var

yn,yk,e,y,a,x,h,h1:real;

d:integer;

koren:boolean;

f:text;

function funk (x,a:real):real;

begin

funk:=ln(x*a)+exp(2*ln(cos(a*x)))/sin(a*x)+SQRT((x+7)/a)+(x+7)+a;

end;

Begin

clrscr;

assign(f,'Otvet.txt');

rewrite(f);

a:=0;h:=0.001;h1:=0.001;

while a<4 do begin

writeln(f,'pri a=',a:8:4);

d:=0;

while x<=10 do begin

if (sin(a*x)<>0) and (x*a>0) and ((x+7)/a>=0) then begin funk (x,a);

if funk (x,a)=0 then begin

d:=d+1;

writeln(f,'x=',x:8:4);

end;

if funk (x,a)* funk (x+h1,a)<0 then

begin d:=d+1;

yn:=x;

yk:=x+h1;

e:=0.0001;

koren:=false;

while (abs(yk-yn)>e) and (not(koren)) do begin

y:=(yk+yn)/2;

if funk (y,a)=0 then koren:=true

else if funk (yn,a)* funk (y,a)<0 then

yk:=y

else yn:=y;

end;

if koren=true then writeln(f,'x=',y:8:4)

else writeln(f,'x=',yn:8:4);

end;

end;

x:=x+h1;

end;

writeln(f,'kopHey ',d);

a:=a+h;

end;

close(f);END.

Результаты счета:

pri a= -1.1000

kopHey 1

x=-9.9990

pri a= -5.0000

kopHey 2

x= -7. 6670

x= -7.0740

pri a= -7.0100

kopHey 3

x= -9.8300

x= -11.6230

x= -18.9510

pri a= -11.2020

kopHey 4

x= -7.0010

x= -9.4230

x= -7.1030

x= -10.4930

pri a= -13.9320

kopHey 5

x= -7.1726

x= -9.2348

x= -9.3293

x= -10.7739

x= -11.3739

Свежие статьи
Популярно сейчас
А знаете ли Вы, что из года в год задания практически не меняются? Математика, преподаваемая в учебных заведениях, никак не менялась минимум 30 лет. Найдите нужный учебный материал на СтудИзбе!
Ответы на популярные вопросы
Да! Наши авторы собирают и выкладывают те работы, которые сдаются в Вашем учебном заведении ежегодно и уже проверены преподавателями.
Да! У нас любой человек может выложить любую учебную работу и зарабатывать на её продажах! Но каждый учебный материал публикуется только после тщательной проверки администрацией.
Вернём деньги! А если быть более точными, то автору даётся немного времени на исправление, а если не исправит или выйдет время, то вернём деньги в полном объёме!
Да! На равне с готовыми студенческими работами у нас продаются услуги. Цены на услуги видны сразу, то есть Вам нужно только указать параметры и сразу можно оплачивать.
Отзывы студентов
Ставлю 10/10
Все нравится, очень удобный сайт, помогает в учебе. Кроме этого, можно заработать самому, выставляя готовые учебные материалы на продажу здесь. Рейтинги и отзывы на преподавателей очень помогают сориентироваться в начале нового семестра. Спасибо за такую функцию. Ставлю максимальную оценку.
Лучшая платформа для успешной сдачи сессии
Познакомился со СтудИзбой благодаря своему другу, очень нравится интерфейс, количество доступных файлов, цена, в общем, все прекрасно. Даже сам продаю какие-то свои работы.
Студизба ван лав ❤
Очень офигенный сайт для студентов. Много полезных учебных материалов. Пользуюсь студизбой с октября 2021 года. Серьёзных нареканий нет. Хотелось бы, что бы ввели подписочную модель и сделали материалы дешевле 300 рублей в рамках подписки бесплатными.
Отличный сайт
Лично меня всё устраивает - и покупка, и продажа; и цены, и возможность предпросмотра куска файла, и обилие бесплатных файлов (в подборках по авторам, читай, ВУЗам и факультетам). Есть определённые баги, но всё решаемо, да и администраторы реагируют в течение суток.
Маленький отзыв о большом помощнике!
Студизба спасает в те моменты, когда сроки горят, а работ накопилось достаточно. Довольно удобный сайт с простой навигацией и огромным количеством материалов.
Студ. Изба как крупнейший сборник работ для студентов
Тут дофига бывает всего полезного. Печально, что бывают предметы по которым даже одного бесплатного решения нет, но это скорее вопрос к студентам. В остальном всё здорово.
Спасательный островок
Если уже не успеваешь разобраться или застрял на каком-то задание поможет тебе быстро и недорого решить твою проблему.
Всё и так отлично
Всё очень удобно. Особенно круто, что есть система бонусов и можно выводить остатки денег. Очень много качественных бесплатных файлов.
Отзыв о системе "Студизба"
Отличная платформа для распространения работ, востребованных студентами. Хорошо налаженная и качественная работа сайта, огромная база заданий и аудитория.
Отличный помощник
Отличный сайт с кучей полезных файлов, позволяющий найти много методичек / учебников / отзывов о вузах и преподователях.
Отлично помогает студентам в любой момент для решения трудных и незамедлительных задач
Хотелось бы больше конкретной информации о преподавателях. А так в принципе хороший сайт, всегда им пользуюсь и ни разу не было желания прекратить. Хороший сайт для помощи студентам, удобный и приятный интерфейс. Из недостатков можно выделить только отсутствия небольшого количества файлов.
Спасибо за шикарный сайт
Великолепный сайт на котором студент за не большие деньги может найти помощь с дз, проектами курсовыми, лабораторными, а также узнать отзывы на преподавателей и бесплатно скачать пособия.
Популярные преподаватели
Добавляйте материалы
и зарабатывайте!
Продажи идут автоматически
5137
Авторов
на СтудИзбе
440
Средний доход
с одного платного файла
Обучение Подробнее