Національний технічний університет України
«Київський політехнічний інститут імені Ігоря Сікорського»
Теплоенергетичний факультет
Кафедра автоматизації проектування енергетичних процесів і систем
ЗВІТ
з Розрахункової Графічної Роботи
з дисципліни «Програмування алгоритмічних структур»
Тема «Програмування розгалужених алгоритмів»
Варіант № 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-го завдання. Метод Гаусса спочатку здався для мене складним, але розібравшись він доволі прімитивний. Зробив звіт з лабораторної роботи та надіслав викладачу на перевірку.