<?xml version="1.0"?>
<rss version="2.0">
   <channel>
      <title>Інформатика by Рудецкий Олег</title>
      <link>https://padlet.com/olegrydeckij/k5wtmazchwkxijcc</link>
      <description></description>
      <language>en-us</language>
      <pubDate>2023-09-04 19:08:55 UTC</pubDate>
      <lastBuildDate>2024-01-18 17:40:01 UTC</lastBuildDate>
      <webMaster>hello@padlet.com</webMaster>
      <image>
         <url></url>
      </image>
      <item>
         <title>04.09.2023. Циклічні алгоритми</title>
         <author>olegrydeckij</author>
         <link>https://padlet.com/olegrydeckij/k5wtmazchwkxijcc/wish/2683714915</link>
         <description><![CDATA[<div><strong><em>Алгоритми з повторенням</em></strong> – <em>це алгоритми, у яких кількість одних і тих самих інструкцій виконується неодноразово.</em>&nbsp;</div><div>&nbsp; Такі алгоритми називають <strong><em>циклічними</em></strong>.</div><div><strong>Приклад</strong></div><div>&nbsp; У морському порту розвантажують вантаж, який містить 10 контейнерів з лимонами, які знаходяться в різних місцях трюму. Потрібно розвантажити їх у порядку їх номерів та визначити вагу кожного контейнера.</div>]]></description>
         <enclosure url="" />
         <pubDate>2023-09-04 19:09:42 UTC</pubDate>
         <guid>https://padlet.com/olegrydeckij/k5wtmazchwkxijcc/wish/2683714915</guid>
      </item>
      <item>
         <title>05.09.2023 МАТЕМАТИЧНІ МОДЕЛІ: ОЗНАЧЕННЯ, ХАРАКТЕРИСТИКИ, ЕТАПИ ПОБУДОВИ </title>
         <author>olegrydeckij</author>
         <link>https://padlet.com/olegrydeckij/k5wtmazchwkxijcc/wish/2711509901</link>
         <description><![CDATA[<div>Математична модель – це наближений опис довільного класу явищ зовнішнього світу, поданий за допомогою математичної символіки<br><br></div><div>Етапи:&nbsp;<br>- постановка задачі<br>- побудова математичної моделі;&nbsp;<br>- дослідження системи на моделі,&nbsp; прогнозування й управління оригіналом за результатами цих досліджень.&nbsp;</div><div>&nbsp; &nbsp;Перший об'єкт називається в цьому випадку <em>оригіналом, </em>а другий – <em>моделлю. <br>&nbsp; &nbsp;</em>До основних характеристик математичних моделей (ММ) належать: ступінь універсальності моделі; точність моделі; адекватність моделі; економічність моделі. <br>&nbsp; За адекватністю фізичної природи аналогічних явищ подібність поділяють на <em>математичну </em>і <em>фізичну </em>(електричну, механічну, теплову тощо).&nbsp;<br>&nbsp; &nbsp;  Побудову математичної моделі можна умовно розбити на 4 етапи: етап змістовного опису; етап формалізації опису; етап остаточної побудови моделі; етап перегляду і вдосконалення моделі за результатами узагальнення емпірично накопичених даних.&nbsp;<br><br></div>]]></description>
         <enclosure url="" />
         <pubDate>2023-09-19 20:12:11 UTC</pubDate>
         <guid>https://padlet.com/olegrydeckij/k5wtmazchwkxijcc/wish/2711509901</guid>
      </item>
      <item>
         <title>21.09.2023</title>
         <author>olegrydeckij</author>
         <link>https://padlet.com/olegrydeckij/k5wtmazchwkxijcc/wish/2718151384</link>
         <description><![CDATA[<div>Чергою називається структура даних, організована за і принципом «першим прийшов — першим пішов».<br><br></div><div>Принцип обробки елементів черги схожий на звичайне формування черги в магазині.<br><br></div><div>і - початок черги, який ще носить назву «голова» черги, та у - кінець черги, що називається «хвостом» черги.<br><br></div><div>Черга є структурою послідовного доступу.<br><br></div>]]></description>
         <enclosure url="" />
         <pubDate>2023-09-24 19:30:34 UTC</pubDate>
         <guid>https://padlet.com/olegrydeckij/k5wtmazchwkxijcc/wish/2718151384</guid>
      </item>
      <item>
         <title>09.10   Тернарний пошук</title>
         <author>olegrydeckij</author>
         <link>https://padlet.com/olegrydeckij/k5wtmazchwkxijcc/wish/2751422348</link>
         <description><![CDATA[<div><strong><br></strong><br></div><div>Тернарний пошук базується на розділенні даних на три рівні замість двох, як у бінарному пошуку. Цей метод особливо корисний у випадках, коли дані мають структуру, що дозволяє ефективно знаходити шукані елементи.<br><br></div><div>Процес тернарного пошуку розпочинається з поділу впорядкованого списку або масиву на три рівні. Шуканий елемент порівнюється з елементами, що знаходяться на двох точках розбиття. Залежно від результату порівняння, пошук може продовжуватись в одному з трьох рівнів.<br><br></div><div>Якщо шуканий елемент менший за першу точку розбиття, пошук продовжується в першій третині даних. Якщо елемент знаходиться між першою і другою точками розбиття, пошук відбувається в середній третині. У випадку, коли елемент більший за другу точку розбиття, пошук проводиться в останній третині даних.<br><br></div><div>Такий поділ даних на три рівні дозволяє швидко зменшувати кількість елементів, з якими потрібно порівнювати шуканий елемент на кожному кроці. Це допомагає знизити час пошуку, особливо коли шуканий елемент знаходиться близько до початку або кінця даних.<br><br></div><div><mark>Основною перевагою </mark>тернарного пошуку є його ефективність у випадках, коли шукані елементи зосереджені навколо певної області даних. В таких ситуаціях тернарний пошук може забезпечити швидкий результат, зменшуючи кількість порівнянь, необхідних для знаходження елемента.<br><br></div><div>Проте, важливо мати на увазі, що тернарний пошук працює ефективно лише з впорядкованими даними. Якщо дані не впорядковані, цей метод може давати неправильні результати.<br><br></div><div>Тернарний пошук широко використовується в різних областях, таких як пошукові системи, оптимізація алгоритмів, графічні ігри та багато інших. Він забезпечує ефективний спосіб пошуку у впорядкованих даних, що дозволяє швидко знаходити потрібні елементи.<br><br></div>]]></description>
         <enclosure url="" />
         <pubDate>2023-10-17 19:21:59 UTC</pubDate>
         <guid>https://padlet.com/olegrydeckij/k5wtmazchwkxijcc/wish/2751422348</guid>
      </item>
      <item>
         <title>11.10  Рядки</title>
         <author>olegrydeckij</author>
         <link>https://padlet.com/olegrydeckij/k5wtmazchwkxijcc/wish/2751442409</link>
         <description><![CDATA[<div>&nbsp; &nbsp; Рядки - це простий тип даних поряд з цілими і дійсними числами. Рядок - це послідовність символів, укладених в одинарні або подвійні лапки. <br>&nbsp; &nbsp; &nbsp;В Python немає символьного типу, типу даних, об'єктами якого є поодинокі символи. Однак мова дозволяє розглядати рядки як об'єкти, що складаються з підрядків довжиною в один і більше символів. При цьому, на відміну від списків, рядки не прийнято відносити до структур даних. <br><strong>Нумерація символів у рядку</strong>&nbsp;<br>&nbsp; &nbsp; &nbsp;Кожний символ у рядку має унікальний порядковий номер — індекс. Нумерація символів починається з нуля. Розглянемо приклади роботи з рядками в інтерактивному режимі До конкретного символу в рядку можна звертатися за його індексом, зазначивши індекс у квадратних дужках.&nbsp;<br>&nbsp; &nbsp; Рядки забезпечують використання всього що може бути представлене у текстовій формі, наприклад:<br>  інформацію у файлах;&nbsp;<br>  дані про імена, описи, коментарі в базах даних;&nbsp;<br>  адреси доменних імен в мережі Internet;&nbsp;<br>  інформаційні тексти в документах, що підтримують кодування Unicode;<br>&nbsp;  інше.&nbsp;<br>У мові Python підтримуються три типи рядків:&nbsp;<br> рядки типу str – призначені для представлення тексту в форматі Unicode та інших системах кодування. Цей формат містить символи в кодуванні ASCII та символи в інших кодуваннях;&nbsp;<br> рядки типу bytes – призначені для представлення двійкових даних;&nbsp;<br> рядки типу bytearray – призначені для представлення двійкових даних з врахуванням змін в типі bytes.&nbsp;<br>У версії Python 2.6 для представлення тексту Unicode використовується тип unicode.&nbsp;</div>]]></description>
         <enclosure url="" />
         <pubDate>2023-10-17 19:38:11 UTC</pubDate>
         <guid>https://padlet.com/olegrydeckij/k5wtmazchwkxijcc/wish/2751442409</guid>
      </item>
      <item>
         <title>16.10  Теорія графів</title>
         <author>olegrydeckij</author>
         <link>https://padlet.com/olegrydeckij/k5wtmazchwkxijcc/wish/2751455558</link>
         <description><![CDATA[<div>Теорія графів – розділ дискретного аналізу, який має широке застосування в багатьох наукових дисциплінах завдяки тому, що поняття і інструментарій цієї теорії виявися дуже зручним для дослідження та інтерпретації різноманітних проблем у великої кількості наук: кібернетиці, технічній і економічній, теорії автоматів, теорії управління, теорії інформації тощо.&nbsp;<br>Графом називається пара двох множин: вершини V і ребер E, що зв’язують вершини. Термін сукупність означає можливість наявності однакових пар.&nbsp;<br>Граф називається скінченим, якщо множини його вершин і ребер є скінченими. Множину вершин графа G позначають V(G), а множину ребер – E(G). Кількість вершин графа – n(G), а кількість ребер графа – m(G).&nbsp;<br>Граф з порожньою множиною ребер називається нуль-графом. Якщо ж множина вершин V – порожня, то порожня і множина E. Такий граф називається порожнім.&nbsp;<br>Граф, що містить кратні ребра, називається мультиграфом.&nbsp;<br>Скінченний неорієнтований граф без петель і кратних ребер називається звичайним.&nbsp;<br>Якщо пари (, )  E вважаються упорядкованими, то граф називається орієнтованим або орграфом. Інакше граф називається неорієнтованим. Ребра орієнтованого графа прийнято називати дугами та зображати направленими відрізками.&nbsp;</div>]]></description>
         <enclosure url="" />
         <pubDate>2023-10-17 19:49:23 UTC</pubDate>
         <guid>https://padlet.com/olegrydeckij/k5wtmazchwkxijcc/wish/2751455558</guid>
      </item>
      <item>
         <title>18.10.2023 Рекурсивний пошук</title>
         <author>olegrydeckij</author>
         <link>https://padlet.com/olegrydeckij/k5wtmazchwkxijcc/wish/2796812957</link>
         <description><![CDATA[<p>Рекурсивний пошук по першому найкращому</p><p>збігу (англ. Recursive Best-First Search — RBFS) — це</p><p>простий рекурсивний алгоритм, в якому робляться</p><p>спроби імітувати роботу стандартного пошуку за</p><p>першим найкращим збігом, але з використанням</p><p>тільки лінійного простору.  Будь-яка функція (метод) у своєму тілі може викликати</p><p>сама себе. Рекурсія – це такий спосіб задавання</p><p>функції, при якому результат повернення з функції для</p><p>даного значення аргументу визначається на основі</p><p>результату повернення з тієї ж функції для</p><p>попереднього (меншого або більшого) значення</p><p>аргументу.</p><p>Якщо функція (метод) викликає сама себе, то такий</p><p>виклик називається рекурсивний виклик функції. При</p><p>кожному рекурсивному виклику запам’ятовуються</p><p>попередні значення внутрішніх локальних змінних та</p><p>переданих у функцію параметрів. Щоб наступний крок</p><p>рекурсивного виклику відрізнявся від попереднього,</p><p>значення як мінімум одного з параметрів функції</p><p>повинно бути змінене. Припинення процесу</p><p>рекурсивних викликів функції відбувається, коли</p><p>змінюваний параметр досягнув деякого кінцевого</p><p>значення, наприклад, оброблено останній елемент в</p><p>масиві.</p>]]></description>
         <enclosure url="" />
         <pubDate>2023-11-20 19:13:53 UTC</pubDate>
         <guid>https://padlet.com/olegrydeckij/k5wtmazchwkxijcc/wish/2796812957</guid>
      </item>
      <item>
         <title>20.10.2023  Пошук у ширину</title>
         <author>olegrydeckij</author>
         <link>https://padlet.com/olegrydeckij/k5wtmazchwkxijcc/wish/2796823853</link>
         <description><![CDATA[<p>Пошук в ширину (обхід в ширину, BFS) - це один з основних алгоритмів на графах.</p><p>В результаті пошуку в ширину знаходиться шлях найкоротшої довжини у незваженому графі, тобто шлях, що містить найменшу кількість ребер.</p><p>Алгоритм працює за <em>O</em>(<em>n</em>+<em>m</em>), де <em>n</em> - кількість вершин, <em>m</em> - кількість ребер.</p><p><strong>Пошук в ширину</strong> – один із базових алгоритмів, що є основою багатьох інших. Наприклад, <a rel="noopener noreferrer nofollow" href="https://www.mathros.net.ua/znahodzhennja-najkorotshogo-shljahu-v-orijentovanomu-grafi-za-algorytmom-dejkstry.html"><strong>алгоритм Дейкстри</strong></a> пошуку найкоротших шляхів з одної вершини і <a rel="noopener noreferrer nofollow" href="https://www.mathros.net.ua/algorytm-pryma.html"><strong>алгоритм Прима</strong></a> пошуку мінімального остового дерева можуть розглядатися як узагальнення <strong>пошуку в ширину</strong>. Згідно з цим алгоритмом обхід вершин заданого графа&nbsp; здійснюється в порядку їх віддаленості від деякої заздалегідь обраної, або зазначеної як початкова, вершини&nbsp; (називається коренем <strong>пошуку в ширину</strong>). Інакше кажучи, спочатку відвідується сама вершина&nbsp;, потім всі вершини, суміжні з&nbsp;, тобто ті, які знаходяться від неї на відстані в одне ребро, потім вершини, що знаходяться від&nbsp; на відстані в два ребра, і так далі.</p><p><br/></p>]]></description>
         <enclosure url="https://padlet-uploads.storage.googleapis.com/1333186405/e5d28656386fac901f9d1873382f44b5/image.png" />
         <pubDate>2023-11-20 19:25:03 UTC</pubDate>
         <guid>https://padlet.com/olegrydeckij/k5wtmazchwkxijcc/wish/2796823853</guid>
      </item>
      <item>
         <title>30.10.2023 Реалізація алгоритму пошуку в ширину</title>
         <author>olegrydeckij</author>
         <link>https://padlet.com/olegrydeckij/k5wtmazchwkxijcc/wish/2796835083</link>
         <description><![CDATA[<p>Наведемо кроки алгоритму</p><ol><li><p>Почати з довільної вершини v. Виконати BFS(v):=1. Включити вершину v у чергу.</p></li><li><p>Розглянути вершину, яка перебуває на початку черги; нехай це буде вершина х. Якщо для всіх вершин, суміжних із вершиною х, уже визначено BFS-номери, то перейти до кроку 4, інакше - до кроку 3.</p></li><li><p>Нехай {x,y} - ребро, у якому номер BFS(у) не визначено. Позначити це ребро потовщеною суцільною лінією, визначити BFS(у) як черговий BFS-номер, включити вершину у чергу й перейти до кроку 2.</p></li><li><p>Виключити вершину х із черги. Якщо черга порожня, то зупинитись, інакше - перейти до кроку 2.</p><p><br/></p><p>Прикладом обходу в ширину може бути поширення інформації про хворобу вчителя. Спочатку один учень, зазвичай староста, взнає про хворобу вчителя і цю важливу інформацію треба поширити серед учнів школи. Що робить учень, він іде і всім, кого зустрічає, розповідає про це. Потім всі ті, кому відома ця інформація, зустрічають інших, кому ще невідома ця інформація, і повідомляють її. Інформація поширюється майже миттєво.</p><p>Розглянемо попередні графи і здійснимо для них обхід в ширину. Почнемо знову з 1-ої вершини. 1-а вершина зв'язана з 2, 4 і 12-ою. Їх ще називають «дітьми». Дивимося, які вершини сумісні з «дітьми»: 2-а вершина ні з якою <strong>новою (нерозглянутою ще)</strong> вершиною не сумісна, 4-а пов'язана з 6-ою і 7-ою, 12-а зв'язана з 10-ою і 11-ою. Всі ці вершини називають «дітьми дітей» або «онуками».&nbsp; Далі розглядаємо всі нові вершини, які сумісні з «онуками»: 6-а пов'язана з 5-ою,&nbsp; 9-ою і 13-ою;&nbsp;&nbsp; 7-а&nbsp; - з 3-ою; 10-а та 11-а несумісні ні з якими новими&nbsp; вершинами. Вершини 5, 9, 13 і 3 є «правнуками», на наступному кроці 5-а вершина сумісна з 8-ою. Обхід графа в ширину можна завершити, бо ми обійшли вже всі вершини.</p><p>На малюнку у дужках подана нумерація вершин по черзі, в якій вершини переглядаюся у процесі пошуку в ширину; вершини- «діти» позначені жовтим кольором, вершини - «онуки» - зеленим, «правнуки» - блакитним, і нарешті «праправнуки» - синім.</p><p><br/></p><p><br/></p><p><br></p></li></ol>]]></description>
         <enclosure url="https://padlet-uploads.storage.googleapis.com/1333186405/11d17501335a189410ee2abc48292c1d/image.png" />
         <pubDate>2023-11-20 19:36:52 UTC</pubDate>
         <guid>https://padlet.com/olegrydeckij/k5wtmazchwkxijcc/wish/2796835083</guid>
      </item>
      <item>
         <title>01.11.2023 Реалізація алгоритму пошуку в глибину</title>
         <author>olegrydeckij</author>
         <link>https://padlet.com/olegrydeckij/k5wtmazchwkxijcc/wish/2796842191</link>
         <description><![CDATA[<p><strong>Обхід графа в глибину — приклад:</strong><br>Використовуючи розглянутий алгоритм побудувати дерево пошуку в глибину наступного неорієнтованого графа:</p><p><strong>ПОБУДОВА ДЕРЕВА ОБХОДУ В ГЛУБИНУ ДЛЯ НЕОРІЄНТОВАНОГО ГРАФА<br></strong></p><p>Отже, починаючи з довільно обраної вершини, наприклад вершини номер «1» рухаємося по першому зустрічному нам ребру (<em>1,2</em>). Так як вершину «2» ми ніколи раніше не відвідували, залишаємося в «2» і проходимо по першому не пройденому ребру, інцидентному «2», а саме (<em>2,3)</em>. Тепер у вершині «3» першим не пройденим ребром являється ребро (<em>3,1).</em> Проходимо його і виявляємо, що вершина «1» вже відвідувалася раніше. Тому повертаємося в «3» і помічаємо ребро (<em>3,1)</em> як зворотне (пунктирною лінією). Повернувшись у вершину «3», шукаємо інше не пройдене ребро і йдемо по першому зустрічному з них, скажімо (<em>3,4)</em>. Так як «4» — нова вершина, залишаємося в ній і шукаємо не пройдене ребро. В даному випадку таким являється ребро (<em>4,2)</em>. Оскільки вершина «2» відвідувалася раніше, позначати ребро (<em>4,2)</em> пунктирною лінією і повертаємося в «4». Через те, що не пройденних ребер, інцидентних «4», не залишилось, повертаємрся у «3».<br>Побудова дерева обходу в глубину для неорієнтованого графа<br>У «3» виявляємо не пройдене ребро (<em>3,5)</em> і проходимо його. Оскільки «5» — нова вершина, залишаємося в ній і шукаємо не прйдене інцидентне їй ребро, яким являється ребро (<em>5,1)</em>. Так як «1» — вже пройдена вершина, помічаємо ребро (<em>5,1)</em> пунктирною лінією. Тепер вершина «5» повністю переглянута, що свідчить про те, що необхідно повернутись у батьківську по відношенню до неї, тобто у вуршину «3». У «3» немає ребер, що залишилися не пройденими, тому, аналогічним чином, рухаємося назад в «2» і, нарешті, в «1». Всі ребра, інцидентні «1», пройдені, що означає кінець процедури.</p><p><br></p>]]></description>
         <enclosure url="https://padlet-uploads.storage.googleapis.com/1333186405/96f39e23a0df88f85f8e891279d57c36/image.png" />
         <pubDate>2023-11-20 19:44:35 UTC</pubDate>
         <guid>https://padlet.com/olegrydeckij/k5wtmazchwkxijcc/wish/2796842191</guid>
      </item>
      <item>
         <title>31.10.2023 Пошук у глибину</title>
         <author>olegrydeckij</author>
         <link>https://padlet.com/olegrydeckij/k5wtmazchwkxijcc/wish/2796848449</link>
         <description><![CDATA[<p>Існує багато алгоритмів на графах, в основі яких лежить систематичний перебір вершин графа, такий що кожна вершина переглядається в точності один раз. Тому важливою задачею є знаходження гарних методів пошуку в графі. Взагалі кажучи, метод «гарний», якщо</p><p>Опишемо такий метод пошуку у неорієнтованому графі, який став однією з основних методик проектування графових алгоритмів. Цей метод називається <strong>пошуком вглиб</strong>.</p><p>Дослідження графа (лабіринта) міфічним героєм Тесеєм з метою вбивства Мінотавра є першим успішним застосуванням пошуку з поверненням на графах, що називається пошуком вглиб.</p><p>Для того, що здійснювати обхід графа вглиб використовується структура даних <strong>стек&nbsp; (</strong>від англ. <strong>Stack</strong> - пачка, стос&nbsp;: у пачку кладуть зверху і беруть також зверху<strong>)</strong>. <strong>Стек - це структура даних з короткою характеристикою типу: останнім прийшов - першим пішов (last-in, first-out&nbsp;&nbsp; --&nbsp; LIFO).&nbsp;&nbsp;</strong></p><p><strong>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;Стек можна уявити&nbsp;у вигляді трубки, запаяної з одного кінця. Наочною ілюстрацією такої трубки є магазин автомата чи гвинтівки. Особливістю магазина є те, що патрон у ньому можна покласти лише з одного кінця (через вікно магазину), при цьому&nbsp;патрони, що там були, протискуються вглиб. І вийняти патрон можна лише через вікно, з того ж кінця; при цьому у вікні з'являється новий патрон із глибини магазин. Легко помітити, що виймати патрони можна лише у порядку, зворотному тому, в якому ми їх клали - це і є особливістю магазину - стеку.</strong></p><p><strong>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; Стеки гарно моделюють стоси об'єктів, таких, як обідні тарілки. Коли тарілка миється, вона поміщується на верхівку стосу. Коли хтось захотів поїсти, то тарілка береться також &nbsp;з верхівки. Стек є належною структурою даних для розв'язання цієї задачі, оскільки все рівно, яка тарілка буде використана наступною.</strong></p><p>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; Найпростішою реалізацію стека є масив (таблиця)&nbsp;зі змінною, що є індексом, який визначає верхівку стека.</p>]]></description>
         <enclosure url="" />
         <pubDate>2023-11-20 19:51:49 UTC</pubDate>
         <guid>https://padlet.com/olegrydeckij/k5wtmazchwkxijcc/wish/2796848449</guid>
      </item>
      <item>
         <title>02.11.2023 Визначення найкоротшого шляху у графі</title>
         <author>olegrydeckij</author>
         <link>https://padlet.com/olegrydeckij/k5wtmazchwkxijcc/wish/2796854489</link>
         <description><![CDATA[<p>В <a rel="noopener noreferrer nofollow" href="https://uk.wikipedia.org/wiki/%D0%A2%D0%B5%D0%BE%D1%80%D1%96%D1%8F_%D0%B3%D1%80%D0%B0%D1%84%D1%96%D0%B2">теорії графів</a>, <strong>задача про найкоротший шлях</strong> полягає в знаходженні такого <a rel="noopener noreferrer nofollow" href="https://uk.wikipedia.org/wiki/%D0%A8%D0%BB%D1%8F%D1%85_(%D1%82%D0%B5%D0%BE%D1%80%D1%96%D1%8F_%D0%B3%D1%80%D0%B0%D1%84%D1%96%D0%B2)">шляху</a> між двома вершинами (або вузлами) графу, що сума ваг ребер з яких він складається мінімальна. Прикладом може бути знаходження найкоротшого шляху між двома пунктами на дорожній мапі; в цьому випадку, вершинами є пункти, а ребрами&nbsp;— відтинки дороги із вагами, рівними часу, необхідному для подолання цього відрізку.</p><p>Формально, маємо зважений граф (це набір вершин <em>V</em> і ребер <em>E</em> з <a rel="noopener noreferrer nofollow" href="https://uk.wikipedia.org/wiki/%D0%94%D1%96%D0%B9%D1%81%D0%BD%D0%B5_%D1%87%D0%B8%D1%81%D0%BB%D0%BE">дійсно</a>-значимою функцією ваги <em>f</em>&nbsp;: <em>E</em>&nbsp;→&nbsp;<strong>R</strong>), і заданим елементом <em>v</em> з <em>V</em>, знайти шлях <em>P</em> з <em>v</em> до <em>v' </em>з <em>V</em> такий, що найменша серед усіх шляхів, що зв'язують <em>v</em> з <em>v' </em>.</p><p>Така задача іноді згадується як <strong>Задача про найкоротший шлях між парою вершин</strong>, щоб відрізнити від наступних узагальнень:</p><ul><li><p><strong>Задача про найкоротші шляхи з одного входу</strong>, тут ми маємо знайти найкоротші шляхи між вхідною вершиною <em>v</em> та всіма іншими вершинами графу.</p></li><li><p><strong>Задача про найкоротші шляхи з одним виходом</strong>, тут ми маємо знайти найкоротші шляхи з усіх вершин графу до однієї вихідної <em>v</em>. Може бути зведена до задачі з одним входом шляхом зміни на зворотні ребер графу.</p></li><li><p><strong>Задача про найкоротші шляхи для всіх пар</strong>, тут ми маємо знайти найкоротші шляхи між кожною парою вершин <em>v</em>, <em>v' </em>в графі.</p></li></ul><p><br/></p><p>Найважливіші алгоритми для розв'язання цієї задачі:</p><ul><li><p><a rel="noopener noreferrer nofollow" href="https://uk.wikipedia.org/wiki/%D0%90%D0%BB%D0%B3%D0%BE%D1%80%D0%B8%D1%82%D0%BC_%D0%94%D0%B5%D0%B9%D0%BA%D1%81%D1%82%D1%80%D0%B8">Алгоритм Дейкстри</a> розв'язує задачі з однією парою, одним входом і одним виходом.</p></li><li><p><a rel="noopener noreferrer nofollow" class="mw-redirect" href="https://uk.wikipedia.org/wiki/%D0%90%D0%BB%D0%B3%D0%BE%D1%80%D0%B8%D1%82%D0%BC_%D0%91%D0%B5%D0%BB%D0%BB%D0%BC%D0%B0%D0%BD%D0%B0-%D0%A4%D0%BE%D1%80%D0%B4%D0%B0">Алгоритм Беллмана-Форда</a> розв'язує задачі з одним входом, якщо ваги ребер можуть бути від'ємні.</p></li><li><p><a rel="noopener noreferrer nofollow" href="https://uk.wikipedia.org/wiki/%D0%90%D0%BB%D0%B3%D0%BE%D1%80%D0%B8%D1%82%D0%BC_%D0%BF%D0%BE%D1%88%D1%83%D0%BA%D1%83_A*">Алгоритм пошуку A*</a> розв'язує задачу для однієї пари із використанням евристики в спробі пришвидшити пошук.</p></li><li><p><a rel="noopener noreferrer nofollow" class="mw-redirect" href="https://uk.wikipedia.org/wiki/%D0%90%D0%BB%D0%B3%D0%BE%D1%80%D0%B8%D1%82%D0%BC_%D0%A4%D0%BB%D0%BE%D0%B9%D0%B4%D0%B0-%D0%92%D0%BE%D1%80%D1%88%D0%B5%D0%BB%D0%BB%D0%B0">Алгоритм Флойда-Воршелла</a> розв'язує задачу для всіх пар.</p></li><li><p><a rel="noopener noreferrer nofollow" href="https://uk.wikipedia.org/wiki/%D0%90%D0%BB%D0%B3%D0%BE%D1%80%D0%B8%D1%82%D0%BC_%D0%94%D0%B6%D0%BE%D0%BD%D1%81%D0%BE%D0%BD%D0%B0">Алгоритм Джонсона</a> розв'язує задачу для всіх пар, і може бути швидшим за алгоритм Флойда-Воршелла на <a rel="noopener noreferrer nofollow" class="mw-redirect" href="https://uk.wikipedia.org/wiki/%D0%A0%D0%BE%D0%B7%D1%80%D1%96%D0%B4%D0%B6%D0%B5%D0%BD%D0%B8%D0%B9_%D0%B3%D1%80%D0%B0%D1%84">розріджених графах</a>.</p></li><li><p><a rel="noopener noreferrer nofollow" href="https://uk.wikipedia.org/wiki/%D0%A2%D0%B5%D0%BE%D1%80%D1%96%D1%8F_%D0%B7%D0%B1%D1%83%D1%80%D0%B5%D0%BD%D1%8C">Теорія збурень</a> знаходить (в найгіршому випадку) локально найкоротший шлях.</p></li></ul>]]></description>
         <enclosure url="" />
         <pubDate>2023-11-20 19:58:39 UTC</pubDate>
         <guid>https://padlet.com/olegrydeckij/k5wtmazchwkxijcc/wish/2796854489</guid>
      </item>
      <item>
         <title>03.11.2023 Алгоритм Дейкстри</title>
         <author>olegrydeckij</author>
         <link>https://padlet.com/olegrydeckij/k5wtmazchwkxijcc/wish/2796855690</link>
         <description><![CDATA[<p><strong>Алгоритм Дейкстри.</strong></p><p>Задача про найкоротший шлях полягає у знаходженні найкоротшого шляху від заданої початкової вершини до заданої кінцевої вершини. Формулювання задач про знаходження відстаней таке:</p><ol><li><p>Для заданої початкової вершини <em>a</em> знайти найкоротші шлахи від <em>a </em>до всіх інших вершин.</p></li><li><p>Знайти найкоротші шляхи між усіма парами вершин.</p></li></ol><p>Виявляється, що майже всі методи розв’язання задачі про найкоротший шлях від заданої початкової вершини до заданої кінцевої вершини, також дають змогу знайти й найкоротші шляхи від вершини <em>a </em>до всіх інших вершин графа. Отже, за їх допомогою можна розв’язати задачу 1 із невеликими додатковими обчислювальними витратами. З іншого боку, задачу 2 можна розв’язати або<em> n </em>разів застосувавши алгоритм задачі 1 із різними початковими вершинами, або один раз застосувавши спеціальний алгоритм<em>.</em></p><p>Алгоритм Дейкстри – найефективніший алгоритм на графах відкритий нідерландським вченим Е.Дейкстром у 1959 році. Цей алгоритм знаходить найкоротшу відстань від однієї вершини графу до всіх решти. Алгоритм працює лише для графів у яких ребра не мають від’ємної ваги. Алгоритм широко застосовується в програмуванні і технологіях, наприклад, його використовують протоколи маршрутизації OSPF та IS-IS.</p>]]></description>
         <enclosure url="" />
         <pubDate>2023-11-20 20:00:15 UTC</pubDate>
         <guid>https://padlet.com/olegrydeckij/k5wtmazchwkxijcc/wish/2796855690</guid>
      </item>
      <item>
         <title>07.11.2023 Алгоритм Флойда-Уоршела</title>
         <author>olegrydeckij</author>
         <link>https://padlet.com/olegrydeckij/k5wtmazchwkxijcc/wish/2796860783</link>
         <description><![CDATA[<p>Алгоритм Флойда-Воршелла&nbsp;— алгоритм динамічного програмування для знаходження найкоротших відстаней між усіма вершинами зваженого орієнтованого графа. Розроблений в 1962 році Робертом Флойдом і Стівеном Воршеллом.</p><p>Динамічне програмування – це альтернативне вирішення задач методом «в лоб», тобто brute forc'ом або жадний алгоритм. Використовується там, де оптимальне вирішення підзадачі меншого розміру може бути використано для вирішення основної задачі. В загальному виді метод виглядає так:</p><ol><li><p>Розбір задачі на під задачі меншого розміру.</p></li><li><p>Знаходження оптимального вирішення під задач рекурсивно.</p></li><li><p>Використання результатів під задач для вирішення основної задачі.</p><p><br></p><p>Алгоритм Флойда-Воршелла можна використовувати для вирішення таких задач:</p><ul><li><p><a rel="noopener noreferrer nofollow" href="https://uk.wikipedia.org/wiki/%D0%97%D0%B0%D0%B4%D0%B0%D1%87%D0%B0_%D0%BF%D1%80%D0%BE_%D0%BD%D0%B0%D0%B9%D0%BA%D0%BE%D1%80%D0%BE%D1%82%D1%88%D0%B8%D0%B9_%D1%88%D0%BB%D1%8F%D1%85">Знаходження найкоротших шляхів у напрямленому графі</a>.</p></li><li><p>Знаходження <a rel="noopener noreferrer nofollow" href="https://uk.wikipedia.org/wiki/%D0%A2%D1%80%D0%B0%D0%BD%D0%B7%D0%B8%D1%82%D0%B8%D0%B2%D0%BD%D0%B5_%D0%B7%D0%B0%D0%BC%D0%B8%D0%BA%D0%B0%D0%BD%D0%BD%D1%8F">транзитивних замикань</a> у <a rel="noopener noreferrer nofollow" href="https://uk.wikipedia.org/wiki/%D0%9E%D1%80%D1%96%D1%94%D0%BD%D1%82%D0%BE%D0%B2%D0%B0%D0%BD%D0%B8%D0%B9_%D0%B3%D1%80%D0%B0%D1%84">напрямленому графі</a>. В оригінальному формулюванні (Воршелла), граф є незважений і представлений <a rel="noopener noreferrer nofollow" href="https://uk.wikipedia.org/wiki/%D0%91%D1%96%D0%BD%D0%B0%D1%80%D0%BD%D0%B0_%D0%BC%D0%B0%D1%82%D1%80%D0%B8%D1%86%D1%8F">булевою матрицею</a>. Операції додавання і мінімуму замінені на логічні <a rel="noopener noreferrer nofollow" href="https://uk.wikipedia.org/wiki/%D0%9A%D0%BE%D0%BD%27%D1%8E%D0%BD%D0%BA%D1%86%D1%96%D1%8F">AND</a> i <a rel="noopener noreferrer nofollow" href="https://uk.wikipedia.org/wiki/%D0%94%D0%B8%D0%B7%27%D1%8E%D0%BD%D0%BA%D1%86%D1%96%D1%8F_(%D0%BB%D0%BE%D0%B3%D1%96%D0%BA%D0%B0)">OR</a>.</p></li><li><p>Знаходження <a rel="noopener noreferrer nofollow" href="https://uk.wikipedia.org/wiki/%D0%A0%D0%B5%D0%B3%D1%83%D0%BB%D1%8F%D1%80%D0%BD%D0%B8%D0%B9_%D0%B2%D0%B8%D1%80%D0%B0%D0%B7">регулярних виразів</a>, що позначають <a rel="noopener noreferrer nofollow" href="https://uk.wikipedia.org/wiki/%D0%A0%D0%B5%D0%B3%D1%83%D0%BB%D1%8F%D1%80%D0%BD%D0%B0_%D0%B3%D1%80%D0%B0%D0%BC%D0%B0%D1%82%D0%B8%D0%BA%D0%B0">регулярні граматики</a>, які приймаються <a rel="noopener noreferrer nofollow" href="https://uk.wikipedia.org/wiki/%D0%A1%D0%BA%D1%96%D0%BD%D1%87%D0%B5%D0%BD%D0%BD%D0%B8%D0%B9_%D0%B0%D0%B2%D1%82%D0%BE%D0%BC%D0%B0%D1%82">скінченним автоматом</a> (<a rel="noopener noreferrer nofollow" class="new" href="https://uk.wikipedia.org/w/index.php?title=%D0%90%D0%BB%D0%B3%D0%BE%D1%80%D0%B8%D1%82%D0%BC_%D0%9A%D0%BB%D1%96%D0%BD%D1%96&amp;action=edit&amp;redlink=1">Алгоритм Кліні</a>, який є узагальненням алгоритму Флойда-Воршелла).</p><p><a rel="noopener noreferrer nofollow" href="https://uk.wikipedia.org/wiki/%D0%9D%D0%B5%D0%B2%D0%B8%D1%80%D0%BE%D0%B4%D0%B6%D0%B5%D0%BD%D0%B0_%D0%BC%D0%B0%D1%82%D1%80%D0%B8%D1%86%D1%8F">Невиродженість матриці</a> в <a rel="noopener noreferrer nofollow" href="https://uk.wikipedia.org/wiki/%D0%9C%D0%B5%D1%82%D0%BE%D0%B4_%D0%93%D0%B0%D1%83%D1%81%D0%B0">методі Гауса</a></p></li><li><p>Оптимальна маршрутизація. У такій постановці задача полягає у знаходженні шляху з максимальним потоком між двома вершинами. Це означає, що замість мінімумів, як у псевдокоді вище, шляхи оптимізуються по максимумах. Вагами ребер задаються фіксовані обмеження на величину потоку. Загальний потік вздовж шляху характеризується ребром з найменшим пропусканням, тому операція додавання замінюється на взяття мінімуму.</p></li><li><p>Знаходження найдовшого шляху.</p></li><li><p>Швидкі обрахунки у <a rel="noopener noreferrer nofollow" class="new" href="https://uk.wikipedia.org/w/index.php?title=Pathfinder_network&amp;action=edit&amp;redlink=1">Pathfinder network</a>.</p></li><li><p>Розрахунок канонічних форм <a rel="noopener noreferrer nofollow" class="new" href="https://uk.wikipedia.org/w/index.php?title=%D0%9C%D0%B0%D1%82%D1%80%D0%B8%D1%86%D1%8F_%D0%BC%D0%B5%D0%B6_%D1%80%D1%96%D0%B7%D0%BD%D0%BE%D1%81%D1%82%D1%96&amp;action=edit&amp;redlink=1">матриць меж різності (DBM)</a></p></li></ul></li></ol>]]></description>
         <enclosure url="" />
         <pubDate>2023-11-20 20:06:39 UTC</pubDate>
         <guid>https://padlet.com/olegrydeckij/k5wtmazchwkxijcc/wish/2796860783</guid>
      </item>
      <item>
         <title>10.11.2023   Динамічне програмування</title>
         <author>olegrydeckij</author>
         <link>https://padlet.com/olegrydeckij/k5wtmazchwkxijcc/wish/2805279391</link>
         <description><![CDATA[<p>Динамічне програмування є потужним і ефективним методом вирішення складних обчислювальних задач. Воно базується на розбитті великої задачі на менші незалежні підзадачі, розв’язок яких може бути запам’ятаний і використаний для вирішення більш складних задач.</p><p>До прикладів застосування динамічного програмування відносяться <strong>задача рюкзака, задача найкоротшого шляху та задача розкладання послідовності</strong>.</p><p>Алгоритм динамічного програмування може бути реалізований за допомогою наступних кроків:</p><ol><li><p>Визначення базових випадків: визначення базових випадків, для яких відомий результат безпосередньо.</p></li><li><p>Рекурсивне визначення значень: визначення значень задачі за допомогою рекурсивного вираховування менших підзадач.</p></li><li><p>Запам’ятовування результатів: запам’ятовування результатів підзадач для уникнення повторних обчислень.</p></li><li><p>Побудова оптимального розв’язку: побудова оптимального розв’язку задачі на основі результатів підзадач.</p></li><li><p>Обчислення результату: обчислення та повернення результату задачі.</p></li></ol>]]></description>
         <enclosure url="" />
         <pubDate>2023-11-28 07:04:39 UTC</pubDate>
         <guid>https://padlet.com/olegrydeckij/k5wtmazchwkxijcc/wish/2805279391</guid>
      </item>
      <item>
         <title>13.11.2023 Жадідні алгоритми</title>
         <author>olegrydeckij</author>
         <link>https://padlet.com/olegrydeckij/k5wtmazchwkxijcc/wish/2805284580</link>
         <description><![CDATA[<p>Жадібний алгоритм - інтуїтивний та ефективний спосіб розв'язання задач оптимізації.</p><p>Основні характеристики жадібних алгоритмів</p><ul><li><p>Локальне оптимальне рішення: На кожному кроці жадібний алгоритм вибирає найкращий доступний варіант, сподіваючись, що це призведе до оптимального рішення загалом.</p></li><li><p>Відсутність зворотного кроку: Жадібні алгоритми не переглядають або не змінюють вже зроблені вибори.</p></li><li><p>Швидкість виконання: Жадібні алгоритми зазвичай є ефективними та швидкими у виконанні завдань.</p><p>Переваги жадібних алгоритмів</p><ul><li><p>Простота реалізації: Жадібні алгоритми зазвичай мають просту структуру та легко реалізуються.</p></li><li><p>Швидкість виконання: Жадібні алгоритми можуть бути дуже швидкими у виконанні завдань.</p></li><li><p>Можливість знаходження оптимального рішення: У деяких випадках жадібні алгоритми можуть знайти оптимальне рішення.</p></li></ul><p>Обмеження жадібних алгоритмів</p><ul><li><p>Локальна оптимальність: Жадібні алгоритми намагаються знайти локально оптимальне рішення на кожному кроці, що може не завжди призводити до глобально оптимального рішення.</p></li><li><p>Недостатня глобальна інформація: Жадібні алгоритми приймають рішення, базуючись на локальних виборах, не враховуючи всю глобальну інформацію.</p></li></ul></li></ul>]]></description>
         <enclosure url="" />
         <pubDate>2023-11-28 07:09:02 UTC</pubDate>
         <guid>https://padlet.com/olegrydeckij/k5wtmazchwkxijcc/wish/2805284580</guid>
      </item>
      <item>
         <title>15.11.2023 Задача про коника-стрибунця</title>
         <author>olegrydeckij</author>
         <link>https://padlet.com/olegrydeckij/k5wtmazchwkxijcc/wish/2805298557</link>
         <description><![CDATA[<p>Коник-стрибунець довго сидів на поділці 0 числової прямої, так довго, що придумав інноваційну методологію свого переміщення. Отже за кожну ітерацію руху він виконує рівно два стрибка, переміщаючись спочатку на a, а потім на b одиничних відрізків по числовій прямій, причому, якщо число додатне, то він рухається вправо, а якщо від’ємне, то вліво. Тривалість стрибка в секундах дорівнює відповідній кількості одиничних відрізків, на яку переміщується коник.</p><p>Наприклад, якщо a = 3, а b = -2, то через 3 сек. він буде на поділці 3, а через 5 сек. від початку руху попаде на відмітку 1. Далі, на 8 секунді переміститься на поділку 4, а на 10 секунді повернеться на 2.</p><p>При заданих a та b знайти скільки необхідно часу в секундах, щоб дострибати до поділки x числової прямої або вивести -1, якщо це неможливо.</p><p><strong>Вхідні дані</strong></p><p>Цілочисельні значення a, b, x — в одному рядку через проміжок. Значення по модулю не перевищують 10^9.</p><p><strong>Вихідні дані</strong></p><p>Відповідь до задачі.</p>]]></description>
         <enclosure url="" />
         <pubDate>2023-11-28 07:23:27 UTC</pubDate>
         <guid>https://padlet.com/olegrydeckij/k5wtmazchwkxijcc/wish/2805298557</guid>
      </item>
      <item>
         <title>22.11.2023 Задача про центи</title>
         <author>olegrydeckij</author>
         <link>https://padlet.com/olegrydeckij/k5wtmazchwkxijcc/wish/2805306835</link>
         <description><![CDATA[<p>Нехай є монети номіналом 25, 10, 5 та 1 цент. Якою найменшою кількістю монет можна видати суму <em>S </em>центів? На думку зразу ж інтуїтивно спадає такий алгоритм розв'язування цієї задачі: спочатку візьмемо максимально можливу кількість монет номіналом 25 центів, але так, щоб ця сума не перевищу, вала <em>S. </em>Потім визначимо, скільки монет номіналом 10 центів не перевищить залишку від <em>S. </em>Ту саму операцію проведемо із монетою номіналом 5 центів. Остаточний залишок видамо мо­нетами 1 цент.</p><p>Цей алгоритм без сумніву можна назвати жадібним і записа­ти у такому вигляді:</p><p>1.&nbsp;&nbsp;&nbsp;&nbsp; Спочатку визначити максимальне <em>п, </em>для якого 25 * <em>n &lt;= S.</em></p><p><em>2. </em>Якщо <em>S - </em>25 <em> п &gt; 0, то визначити максимальне m, для яко­го 10 </em> <em>m &lt;= S - </em>25 * n; у протилежному випадку перейти до п. 5.</p><p>3.&nbsp;&nbsp;&nbsp;&nbsp; Якщо S - 25 <em> п - 10 </em> <em>m &gt; </em>0, то визначити максимальне <em>k, </em>для якого 5 <em> k &lt;= S - 25 </em> <em>п - </em>10 * n; у протилежному випадку перейти до п. 5.</p><p>4.&nbsp;&nbsp;&nbsp;&nbsp; Якщо S - 25 <em> n - 10 </em> <em>m - 5  k &gt; 0, то суму S - 25 </em> <em>п - </em>10 ** <em>m </em>- 5 * <em>k </em>видати монетами номіналом 1 цент.</p><p>5.&nbsp;&nbsp;&nbsp;&nbsp; Завершити алгоритм.</p>]]></description>
         <enclosure url="" />
         <pubDate>2023-11-28 07:31:18 UTC</pubDate>
         <guid>https://padlet.com/olegrydeckij/k5wtmazchwkxijcc/wish/2805306835</guid>
      </item>
      <item>
         <title>23.11.2023 Задача про заявки</title>
         <author>olegrydeckij</author>
         <link>https://padlet.com/olegrydeckij/k5wtmazchwkxijcc/wish/2805311367</link>
         <description><![CDATA[<p><strong>Задача.</strong> Є <em>n</em> заявок на проведення занять в деякій аудиторії. У заявці з номером <em>j</em> вказано два числа <em>s<sub>j</sub></em> і <em>f<sub>j</sub></em> — початок і кінець заняття (у хвилинах від початку доби). Заявки з номерами <em>j</em> та <em>k</em> сумісні, якщо проміжки [<em>s<sub>j</sub></em> , <em>f<sub>j</sub></em> ) і [<em>s<sub>k</sub></em> , <em>f<sub>k</sub></em> ) не перетинаються, тобто справджується одна з нерівностей: <em>f<sub>j</sub></em> ≤ <em>s<sub>k</sub></em> або <em>f<sub>k</sub></em> ≤ <em>s<sub>j</sub></em>. Перший рядок файлу input.txt містить запис числа <em>n</em>. Кожний з наступних <em>n</em> рядків містить записи двох чисел: початку й кінця заняття. Потрібно записати у файл output.txt:</p><ul><li><p>у перший рядок максимальну кількість сумісних між собою заявок;</p></li><li><p>у другий рядок номери відповідних заяв у порядку виконання.</p></li></ul><p><strong>Алгоритм розв'язання задачі про вибір заявок</strong></p><ol><li><p>Упорядкувати заявки за зростанням часу закінчення.</p></li><li><p>Надати множині заяв (відповіді) значення порожньої множини.</p></li><li><p>До множини заяв відповіді включити першу (після упорядкування) заявку.</p></li><li><p>Знайти у переліку першу заявку, що починається не раніше закінчення останньої, включеної у відповідь.</p></li><li><p>Включити знайдену заявку до множині заяв (відповіді).</p></li><li><p>Два попередні кроки повторювати доти, поки при пошуку чергової заявки не буде досягнуто кінця переліку заяв.</p></li></ol><p>Зауважимо: після відкидання усіх заявок, що суперечать останній, долученій до списку, отримаємо початкову задачу з меншою кількістю заявок. Використавши індукцію, приходимо до висновку про оптимальність розв'язку.</p>]]></description>
         <enclosure url="" />
         <pubDate>2023-11-28 07:35:07 UTC</pubDate>
         <guid>https://padlet.com/olegrydeckij/k5wtmazchwkxijcc/wish/2805311367</guid>
      </item>
      <item>
         <title>24.11.2023 Загальна задача динамічного програмування</title>
         <author>olegrydeckij</author>
         <link>https://padlet.com/olegrydeckij/k5wtmazchwkxijcc/wish/2805316325</link>
         <description><![CDATA[<p> Після розгляду найтиповіших задач динамічного програмування, простіше сформулювати його основні ідеї.</p><p>P. Беллманом був сформульований принцип оптимальності: якою не була б інформація, що обробляється, перед черговим етапом необхідно вибрати стратегію на поточному етапі так, щоб виграш на цьому етапі плюс оптимальний виграш на всіх наступних етапах був максимальним.</p><p>Зробимо ще одне зауваження: у будь-якій задачі динамічного програмування «початок» і «кінець» можна поміняти місцями.</p><p>Як розпізнати задачу динамічного програмування? Насамперед варто зазначити, що найкращим критерієм «впізнавання» задач динамічного програмування є власний значний досвід у розв'язуванні таких задач. Разом з тим, можна дати й деякі поради. Спочатку треба розглянути питання про можливість розбиття задачі на етапи, що найчастіше міститься вже у формулюванні самої задачі, як, наприклад, дослідження (аналіз) фінансування одного підприємства по роках або кількох окремих підприємств в економічних задачах. Але іноді таке розбиття необхідно робити штучно, як, наприклад, у задачі про прокладання найвигіднішого шляху. Кількість етапів у задачі найчастіше визначається так само в умові задачі. Якщо ж їх доводиться визначати самостійно, то необхідно орієнтуватися на тип змінних, обумовлених у задачі, на критерії визначення кінцевого результату. Не можна забувати, що в разі збільшення кількості етапів значно зростає об'єм розрахунків, що у свою чергу впливає на загальний час виконання алгоритму</p>]]></description>
         <enclosure url="" />
         <pubDate>2023-11-28 07:39:09 UTC</pubDate>
         <guid>https://padlet.com/olegrydeckij/k5wtmazchwkxijcc/wish/2805316325</guid>
      </item>
      <item>
         <title>27.11.2023 Критерії застосування задач динамічного програмування</title>
         <author>olegrydeckij</author>
         <link>https://padlet.com/olegrydeckij/k5wtmazchwkxijcc/wish/2805335747</link>
         <description><![CDATA[<p>Поняття “динамічне програмування” придумав і назвав 1940 року Річард Беллман, а змінив і доповнив його визначення – 1953 року. Беллману довелося багато часу витратити на вибір назви, бо його бос не любив математичні терміни. Тому автор визначення вибрав слово “програмування” замість “планування” і слово “динамічне”, щоб уникнути принизливих і лайливих тлумачень з боку керівника. Ось так було сформовано назву “динамічне програмування”.</p><p>Важливо враховувати такі моменти:</p><ol><li><p>Для ефективного застосування цього підходу необхідно запам’ятовувати рішення підзадач.</p></li><li><p>Підзадачі мають загальну структуру, що дає змогу використовувати однорідний спосіб їх розв’язання, замість того, щоб кожну вирішувати окремо різними алгоритмами.</p><p><strong>Підсумок</strong></p><p>У майбутньому метод динамічного програмування продовжуватиме використовуватися в різних галузях, як-от фінанси, виробництво, транспорт і багатьох інших, для розв’язання складних завдань оптимізації. Однак, необхідно продовжувати дослідження в галузі розроблення нових алгоритмів, які будуть більш ефективні та універсальні для вирішення різних завдань.</p></li></ol>]]></description>
         <enclosure url="" />
         <pubDate>2023-11-28 07:56:06 UTC</pubDate>
         <guid>https://padlet.com/olegrydeckij/k5wtmazchwkxijcc/wish/2805335747</guid>
      </item>
      <item>
         <title>13.11.2023 Використання бази даних у сучасному житті</title>
         <author>olegrydeckij</author>
         <link>https://padlet.com/olegrydeckij/k5wtmazchwkxijcc/wish/2832792815</link>
         <description><![CDATA[<p>Використання баз даних у сучасному житті є важливим аспектом для зручного та ефективного управління інформацією. Вони застосовуються у бізнесі, науці, медицині та інших галузях для зберігання, оновлення та аналізу великих обсягів даних, сприяючи при цьому прийняттю обґрунтованих рішень та оптимізації процесів.</p><ol><li><p><strong>Бізнес:</strong> Бази даних використовуються у бізнесі для зберігання клієнтської інформації, відстеження запасів, та управління транзакціями. Наприклад, система управління клієнтами (CRM) дозволяє компаніям зберігати та аналізувати дані про клієнтів для покращення обслуговування.</p></li><li><p><strong>Освіта:</strong> У навчальних закладах бази даних використовуються для зберігання академічної інформації, реєстрації студентів, та оцінювання успішності. Наприклад, університетська система може використовувати базу даних для ефективного обліку студентів та їхніх результатів.</p></li><li><p><strong>Медицина:</strong> В медичній галузі бази даних забезпечують зберігання пацієнтських історій, результатів аналізів, та рецептів. Наприклад, електронні медичні записи дозволяють швидко доступатися до важливої інформації для надання якісної медичної допомоги.</p></li><li><p><strong>Технології:</strong> У сфері інформаційних технологій бази даних використовуються для зберігання конфігураційних даних, логів подій, та управління користувачами. Наприклад, системи керування базами даних (DBMS) дозволяють ефективно організовувати та обробляти дані.</p></li></ol><p>Ці приклади відображають важливість баз даних у різних галузях сучасного життя для забезпечення ефективного управління та використання інформації.</p>]]></description>
         <enclosure url="" />
         <pubDate>2023-12-23 12:45:54 UTC</pubDate>
         <guid>https://padlet.com/olegrydeckij/k5wtmazchwkxijcc/wish/2832792815</guid>
      </item>
      <item>
         <title>15.12.2023 Проєктування баз даних. Поняття сутності, атрибута, ключа, зв’язку. Модель «сутність-зв’язок» предметної області. </title>
         <author>olegrydeckij</author>
         <link>https://padlet.com/olegrydeckij/k5wtmazchwkxijcc/wish/2832799811</link>
         <description><![CDATA[<p><strong>БД</strong>-це впорядкований за певними правилами набір взаємопов’язаних даних. На початку проектування баз даних, як правило, розробляється модель предметної області, для якої створюється ця БД. У ній указуються типи об’єктів, що будуть включені до бази даних, і зв’язки між ними. Для наочності таку модель можна подати у графічному вигляді.</p><p><strong><mark>Сутність</mark></strong> — це деякий об’єкт реального світу. Вона має екземпляри, які відрізняються один від одного значеннями атрибутів. </p><p><strong><mark>Атрибут</mark></strong> — це властивість сутності. Зв’язок фактично встановлює взаємодію між сутностями.</p><p><em> </em>Деякі з атрибутів є <strong><mark>ключовими</mark></strong> – вони дозволяють унікально ідентифікувати об’єкт сутності. Наприклад, у людей можуть повторюватись прізвище, ім’я, по батькові, проте не може повторюватись номер паспорту. І знаючи цей номер, ми можемо точно дізнатись, котрий саме Іваненко Тарас Михайлович відкрив рахунок у банку. Отже людину можна ідентифікувати за номером паспорта.</p><p>Передусім потрібно знати, що <strong><mark>типів зв’язків</mark></strong> є всього три: один до одного, один до багатьох і багато до багатьох.</p><p><br></p><p><strong>Один до одного</strong> – це клас та класний керівник. В одного класу може бути лише один класний керівник, і вчитель може бути класним керівником лише одного класу. Тому – 1 до 1.</p><p><strong>Один до багатьох</strong> – у класі вчиться багато учнів, але учень вчиться лише в одному класі. У школі багато класів, але конкретний клас&nbsp; належить лише до однієї школи.</p><p>І <strong>багато до багатьох</strong> – вчитель викладає у багатьох класах, а у класі викладає багато вчителів. Актор знімається у багатьох фільмах, а у фільмі знімається багато акторів.</p><p>Більше ніяких типів зв’язків не буває, всіх їх можна віднести до одного з трьох типів.</p>]]></description>
         <enclosure url="" />
         <pubDate>2023-12-23 13:03:13 UTC</pubDate>
         <guid>https://padlet.com/olegrydeckij/k5wtmazchwkxijcc/wish/2832799811</guid>
      </item>
      <item>
         <title>18.12.2023  Бази даних в інформаційних системах</title>
         <author>olegrydeckij</author>
         <link>https://padlet.com/olegrydeckij/k5wtmazchwkxijcc/wish/2832803031</link>
         <description><![CDATA[<p>База даних набуває цінності в складі інформаційної системи (ІС) та є однією з найважливіших її складових.</p><p>Інформаційні системи класифікують за багатьма ознаками, із яких однією із найголовніших є спосіб доступу користувачів до бази даних. За цією ознакою їх поділяють на <strong><mark>автономні , групові, корпоративні, глобальні.</mark></strong></p><p>В БД використовуються класичні моделі даних: <strong><mark>ієрархічна, мережева, реляційна та об’єктно-орієнтовна. </mark></strong>Ієрархічна модель є зручною для роботи з ієрархічно впорядкованою інформацією та громіздка для інформації зі складними логічними зв’язками. Мережева модель — це представлення даних у вигляді довільного графа. Перевагою мережевої та ієрархічної моделей є їх ефективність реалізації по затратам пам’яті. Недоліком мережевої моделі даних є складність схеми БД. Реляційну модель запропонував американський математик Едгар Кодд, який довів, що будьяка сукупність даних предметної галузі може бути подана взаємопов‘язаними між собою математичними відношеннями. Об’єктноорієнтовні БД об’єднують в собі дві моделі даних, реляційну та мережеву, використовуються при створенні великих БД зі складними структурами даних. Модельданих в загальному випадку описує набір базових ознак, які мають бути притаманні СУБД заснованій на цій моделі, тому тип СУБД відповідає типу моделі даних. За характером використання СУБД ділять на персональні, наприклад, VisualFoxPro, Paradox, Clipper, dBase, Access та мережеві (багатокористувацькі), наприклад, Oracle, MS SQL, MySQL, lnformix тощо.</p>]]></description>
         <enclosure url="" />
         <pubDate>2023-12-23 13:11:26 UTC</pubDate>
         <guid>https://padlet.com/olegrydeckij/k5wtmazchwkxijcc/wish/2832803031</guid>
      </item>
      <item>
         <title>19.12.2023 Основні відомості про СУБД Access.</title>
         <author>olegrydeckij</author>
         <link>https://padlet.com/olegrydeckij/k5wtmazchwkxijcc/wish/2832804393</link>
         <description><![CDATA[<p>Microsoft Access є системою управління базами даних (СУБД) та частиною пакета Microsoft Office. Основні відомості про Microsoft Access включають:</p><ol><li><p><strong>Інтерфейс:</strong></p><ul><li><p>Access має інтуїтивний графічний інтерфейс, що дозволяє користувачам створювати та управляти базами даних без необхідності великих навичок програмування.</p></li></ul></li><li><p><strong>Таблиці:</strong></p><ul><li><p>Основною одиницею зберігання даних в Access є таблиці. Вони можуть містити різні типи даних, такі як текст, числа, дата та інші.</p></li></ul></li><li><p><strong>Запити:</strong></p><ul><li><p>Access надає можливості створення запитів для вибірки, фільтрації та обробки даних з таблиць.</p></li></ul></li><li><p><strong>Форми:</strong></p><ul><li><p>Використовуються для створення користувацьких інтерфейсів для введення та перегляду даних. Форми полегшують взаємодію з користувачем.</p></li></ul></li><li><p><strong>Звіти:</strong></p><ul><li><p>Дозволяють створювати різні види звітів на основі даних з таблиць чи запитів.</p></li></ul></li><li><p><strong>Макроси та VBA:</strong></p><ul><li><p>Access підтримує використання макросів для автоматизації рутинних завдань. Також, ви можете використовувати мову програмування VBA для створення більш складних скриптів та додаткової функціональності.</p></li></ul></li><li><p><strong>Підтримка зовнішніх джерел даних:</strong></p><ul><li><p>Можливість підключення до зовнішніх джерел даних, таких як SQL Server, Excel, SharePoint тощо.</p></li></ul></li><li><p><strong>Безпека:</strong></p><ul><li><p>Access надає можливості встановлення різного рівня доступу та захисту для даних.</p></li></ul></li><li><p><strong>Інтеграція з іншими продуктами Microsoft:</strong></p><ul><li><p>Access добре інтегрується з іншими програмами Microsoft Office, що полегшує обмін даними та роботу з ними.</p></li></ul></li><li><p><strong>Шаблони:</strong></p><ul><li><p>Access має готові шаблони баз даних, які полегшують створення баз для різних потреб, таких як керування проектами, інвентарем, клієнтами тощо.</p></li></ul></li></ol>]]></description>
         <enclosure url="" />
         <pubDate>2023-12-23 13:14:49 UTC</pubDate>
         <guid>https://padlet.com/olegrydeckij/k5wtmazchwkxijcc/wish/2832804393</guid>
      </item>
      <item>
         <title>20.12.2023 Класифікація зв’язків за множинністю та обов’язковістю</title>
         <author>olegrydeckij</author>
         <link>https://padlet.com/olegrydeckij/k5wtmazchwkxijcc/wish/2832805296</link>
         <description><![CDATA[<p>У базах даних зв'язки між таблицями можуть мати різні характеристики, такі як множинність (як кілька записів з таблиці A може бути пов'язано з кількома записами з таблиці B) та обов'язковість (чи є у зв'язку обов'язковий запис в одній з таблиць). Класифікація зв'язків включає такі типи:</p><p><strong>За множинністю:</strong></p><ol><li><p><strong>Один до одного (1:1):</strong></p><ul><li><p>Кожен запис у першій таблиці пов'язаний з одним записом у другій таблиці, і навпаки.</p></li></ul></li><li><p><strong>Один до багатьох (1:N):</strong></p><ul><li><p>Кожен запис у першій таблиці пов'язаний з багатьма записами у другій таблиці, але кожен запис у другій таблиці може мати лише один запис у першій таблиці.</p></li></ul></li><li><p><strong>Багато до багатьох (M:N):</strong></p><ul><li><p>Кожен запис у першій таблиці пов'язаний з багатьма записами у другій таблиці, і навпаки. Це реалізується через додаткову (проміжну) таблицю.</p></li></ul></li></ol><p><strong>За обов'язковістю:</strong></p><ol><li><p><strong>Обов'язковий зв'язок (mandatory/required):</strong></p><ul><li><p>Кожен запис у першій таблиці пов'язаний з одним чи більше записами у другій таблиці.</p></li></ul></li><li><p><strong>Необов'язковий зв'язок (optional):</strong></p><ul><li><p>Кожен запис у першій таблиці може бути пов'язаний з нулем чи одним записом у другій таблиці.</p></li></ul></li></ol><p>Ці характеристики визначаються в процесі проектування бази даних і визначають, як дані будуть зберігатися та оброблятися у взаємодії між таблицями.</p>]]></description>
         <enclosure url="" />
         <pubDate>2023-12-23 13:16:57 UTC</pubDate>
         <guid>https://padlet.com/olegrydeckij/k5wtmazchwkxijcc/wish/2832805296</guid>
      </item>
      <item>
         <title>27.12.2023 Сортування та фільтрація записів. Операції над таблицями.</title>
         <author>olegrydeckij</author>
         <link>https://padlet.com/olegrydeckij/k5wtmazchwkxijcc/wish/2833138322</link>
         <description><![CDATA[<p>Сортуванням називають розташування записів таблиці в по­рядку зростання чи спадання значень певного поля. Сортуван­ня, нагадаємо, найчастіше застосовують у випадках, коли:</p><p>v необхідно дізнатися, які об’єкти мають малі, великі, най­менші або найбільші значення тих чи інших параметрів (адже після сортування такі об’єкти розміщуватимуться на початку таблиці);</p><p>v потрібно згрупувати об’єкти за певним параметром, тобто розташувати поряд об’єкти з однаковими чи близькими його значеннями.</p><p>Як і в табличному процесорі, фільтрація в СКБД Microsoft Access дозволяє відобразити тільки ті записи таблиці, що задо­вольняють певну умову. Щоб виконати фільтрацію, слід відк­рити таблицю і клацнути кнопку (Змінити фільтр), що роз­ташована на панелі інструментів у MS Access 2003. У MS Access 2007/2010 аналогічну команду розміщено на стрічці Главная в області Сортировка и фильтр у меню кнопки Дополнительно.</p>]]></description>
         <enclosure url="" />
         <pubDate>2023-12-24 12:12:19 UTC</pubDate>
         <guid>https://padlet.com/olegrydeckij/k5wtmazchwkxijcc/wish/2833138322</guid>
      </item>
      <item>
         <title>26.12.2023 Уведення, пошук і редагування даних у таблиці</title>
         <author>olegrydeckij</author>
         <link>https://padlet.com/olegrydeckij/k5wtmazchwkxijcc/wish/2833139749</link>
         <description><![CDATA[<p>Дані в таблиці можна вводити після створення їх структур. Існує два способи введення даних у таблиці: за допомогою форм і безпосереднє введення даних таблиці.</p><p>Під час уведення даних автоматично перевіряються такі типи даних: числові, грошові, дата і час, логічні.</p><p>На вкладці Основне в групі Форматування тексту містяться елементи, за допомогою яких можна змінити розмір і накреслення символів та інші параметри. Якщо на екрані не поміщаються всі записи, слід скористатися вертикальною смугою прокручування, а якщо не поміщаються всі поля — горизонтальною. Окремі поля можна розширити або звузити звичайним порядком. У нижній частині вікна таблиці розміщено кнопки навігації для переміщення курсора в перший, сусідній або останній запис.</p><p>Потрібний запис у таблиці можна знайти за значенням будь-якого її поля або за фрагментом його значення.</p><p>Після завершення пошуку на знайдений запис встановлюється курсор, і поле цього рядка висвітлюється іншим кольором. Оскільки в таблиці може бути кілька значень, що відшукуються, то для продовження пошуку необхідно ще раз натиснути кнопку Знайти далі. Для пошуку першого входження зразка можна використовувати поле Пошук. Пошук завершується після першого визначення рядка. Знайдене значення можна змінювати, вводити нове. Поле типу Лічильник, заблоковані поля та поля, що обчислюються, змінювати не можна.</p>]]></description>
         <enclosure url="" />
         <pubDate>2023-12-24 12:18:48 UTC</pubDate>
         <guid>https://padlet.com/olegrydeckij/k5wtmazchwkxijcc/wish/2833139749</guid>
      </item>
      <item>
         <title>17.01.2024 Загальні відомості про запити</title>
         <author>olegrydeckij</author>
         <link>https://padlet.com/olegrydeckij/k5wtmazchwkxijcc/wish/2853726459</link>
         <description><![CDATA[<p><strong>Запит</strong> — це один із основних об'єктів БД Access 2016. Головним призначенням запиту є відбір із таблиць потрібних даних, їх опрацювання й подання користувачеві в зручній формі.</p><p>Запити не містять даних. Під час кожного нового виконання запиту формуються необхідні дані з тих таблиць, на основі яких його створено.</p><p><em>До простих</em> запитів належать такі, за якими вибираються дані за критерієм одного поля однієї таблиці. Наприклад, простими є такі запити: вибрати з таблиці</p><p>МАГАЗИНИ ті номери магазинів, де кількість працівників більше 13, вибрати з таблиці КАДРИ прізвища тих працівників, які народилися після 1979 року.</p><p><em>До складних</em> належать запити, за якими формуються дані з кількох таблиць за критеріями кількох полів.</p><p>У запитах різних типів найчастіше реалізуються такі операції:</p><ul><li><p>&nbsp; вибір даних із вказаних полів на основі заданих критеріїв;</p></li><li><p> упорядкування даних із таблиць за значеннями вказаних полів;</p></li><li><p>побудова нової таблиці або діаграми з отриманих даних;</p></li><li><p>опрацювання вибраних із таблиць даних за допомогою вбудованих функцій;</p></li><li><p>використання отриманих за допомогою запиту даних як джерела для інших запитів;</p></li><li><p>додавання даних, отриманих за допомогою запитів, до інших таблиць;</p></li><li><p>обмін даними з іншими БД, а також текстовим редактором Word і таблицями Excel.</p></li></ul><p>У запитах можуть використовуватися специфічні оператори.</p><p><br/></p>]]></description>
         <enclosure url="" />
         <pubDate>2024-01-18 17:40:01 UTC</pubDate>
         <guid>https://padlet.com/olegrydeckij/k5wtmazchwkxijcc/wish/2853726459</guid>
      </item>
   </channel>
</rss>
