Програмування розгалужених алгоритмів

Інформація про навчальний заклад

ВУЗ:
Національний технічний університет України Київський політехнічний інститут
Інститут:
О
Факультет:
Не вказано
Кафедра:
Не вказано

Інформація про роботу

Рік:
2021
Тип роботи:
Звіт
Предмет:
Програмування алгоритмічних структур

Частина тексту файла (без зображень, графіків і формул):

Національний технічний університет України «Київський політехнічний інститут імені Ігоря Сікорського» Теплоенергетичний факультет Кафедра автоматизації проектування енергетичних процесів і систем ЗВІТ з Розрахункової Графічної Роботи з дисципліни «Програмування алгоритмічних структур» Тема «Програмування розгалужених алгоритмів» Варіант № 18 Київ – 2021 Завдання на роботу. 1. Розробити алгоритми і написати програми мовою Java із застосуванням операторів циклів for, while, do while для розв’язання завдань, поданих в додатках 1,2 відповідно до індивідуального варіанта. Варіант обрати за списком групи. 2. Розробити програмний проект в середовищі IntellijIDEA для реалізації написаних програм. Перевірити результати обчислень альтернативними розрахунками(наприклад, Excel, калькулятор, тощо). 3. Оформити РГР та вчасно надіслати викладачу на перевірку файл РГР та файл програми. Опис завдання табл. 1 для варіанта 18: Опис завдання табл. 2: Блок-схема до розв’язку завдання табл. 2: Код програми: public class RgrTr15Chere { public static void main(String[] args) { System.out.println("Stating matrix:"); double[][] arr = { {-8., 10., 10., 1., 8., -120.2}, {6., -7., -7., -8., 7., -8.9}, {0., -2., 5., 0., 6., -51.9}, {3., -1., -1., -5., -6., 65.4}, {-2., 8., -3., 8., -1., -44.3} }; for (double[] e: arr) { System.out.print("|"); for (double ee: e) { System.out.print(ee + "|"); } System.out.println(); } for (double[] e : arr) { System.out.println(e[0] + "x1 + " + e[1] + "x2 + " + e[2] + "x3 + " + e[3] + "x4 + " + e[4] + "x5 = " + e[5]); } System.out.println(); double[] result = task1(arr); System.out.println("Result:"); int index = (int) '1'; for (double x: result) { System.out.printf("x%c = %.3f\n", ((char) index++), x); } System.out.println(); Scanner input = new Scanner(System.in); System.out.print("Task2 input number: "); int num = input.nextInt(); System.out.print("Task2 result: "); int[] result2 = task2(num); for (int e: result2) { System.out.print(e + "; "); } System.out.print("\nTask2 input number: "); num = input.nextInt(); System.out.print("Task2 result: "); result2 = task2(num); for (int e: result2) { System.out.print(e + "; "); } System.out.print("\nTask2 input number: "); num = input.nextInt(); System.out.print("Task2 result: "); result2 = task2(num); for (int e: result2) { System.out.print(e + "; "); } } static double[] task1(double[][] arr) { double[] lastInRow = new double[arr.length]; for (int i = 0; i < lastInRow.length; i++) { lastInRow[i] = arr[i][arr[i].length - 1]; } double m; for (int i = 1; i < arr.length; i++) { for (int j = i; j < arr.length; j++) { m = arr[j][i - 1] / arr[i - 1][i - 1]; for (int k = 0; k < arr[j].length; k++) { arr[j][k] = arr[j][k] - m * arr[i - 1][k]; } lastInRow[j] = lastInRow[j] - m * lastInRow[i - 1]; } } System.out.println("Triangle matrix:"); for (double[] e : arr) { System.out.printf("%.3fx1 + %.3fx2 + %.3fx3 + %.3fx4 + %.3fx5 = %.3f\n", e[0], e[1], e[2], e[3], e[4], e[5]); } System.out.println(); for (int i = arr.length-1; i >= 0; i--) { for (int j = i + 1; j < arr.length; j++) lastInRow[i] -= arr[i][j] * lastInRow[j]; lastInRow[i] = lastInRow[i] / arr[i][i]; } return lastInRow; } static int[] task2(int num) { int howMany = 0; int num2 = num; while (num != 0) { if (num % 10 % 5 == 0) howMany++; num /= 10; } int[] result = new int[howMany]; int i = 0; while (num2 != 0) { if (num2 % 10 % 5 == 0) { result[i] = num2 % 10; i++; } num2 /= 10; } return result; } } Результати рішення програми Висновок Я написав мовою Java 2 алгоритми із застосуванням циклів for та while для розв’язання завдань, поданих в табл. 1-2 відповідно до індивідуального варіанта 18. Розробив програмні проекти в середовищі Intellij IDEA для реалізації написаних програм. Перевірив результати обчислень альтернативними розрахунками. Ознайомився із математичним алгоритмом Гаусса для вирішення СЛАР. Разробив блок схему 2-го завдання. Метод Гаусса спочатку здався для мене складним, але розібравшись він доволі прімитивний. Зробив звіт з лабораторної роботи та надіслав викладачу на перевірку.
Антиботан аватар за замовчуванням

19.06.2023 18:06-

Коментарі

Ви не можете залишити коментар. Для цього, будь ласка, увійдіть або зареєструйтесь.

Ділись своїми роботами та отримуй миттєві бонуси!

Маєш корисні навчальні матеріали, які припадають пилом на твоєму комп'ютері? Розрахункові, лабораторні, практичні чи контрольні роботи — завантажуй їх прямо зараз і одразу отримуй бали на свій рахунок! Заархівуй всі файли в один .zip (до 100 МБ) або завантажуй кожен файл окремо. Внесок у спільноту – це легкий спосіб допомогти іншим та отримати додаткові можливості на сайті. Твої старі роботи можуть приносити тобі нові нагороди!
Нічого не вибрано
0%

Оголошення від адміністратора

Антиботан аватар за замовчуванням

Подякувати Студентському архіву довільною сумою

Admin

26.02.2023 12:38

Дякуємо, що користуєтесь нашим архівом!