SHOW:
|
|
- or go back to the newest paste.
1 | using System; | |
2 | using System.Collections.Generic; | |
3 | using System.Linq; | |
4 | using System.Text; | |
5 | using System.Threading.Tasks; | |
6 | using System.IO; | |
7 | using System.Globalization; | |
8 | ||
9 | namespace Matrix | |
10 | { | |
11 | - | { |
11 | + | |
12 | - | string dataName ="data" + Console.ReadLine(); |
12 | + | |
13 | - | dataName += ".txt"; |
13 | + | |
14 | - | |
14 | + | |
15 | - | var data = File.ReadAllLines(dataName); |
15 | + | Console.WriteLine("введите название файла *data#.txt*"); |
16 | - | |
16 | + | int NumbX = 0; |
17 | var userInput = Console.ReadLine(); | |
18 | - | |
18 | + | var data = File.ReadAllLines(userInput); |
19 | var numberOfur = int.Parse(data[0]); | |
20 | - | |
20 | + | |
21 | var sqrs = new double[numberOfur]; | |
22 | - | |
22 | + | |
23 | var determinant = CalculateDeterminat(mathrix, sqrs); | |
24 | - | |
24 | + | |
25 | foreach (var a in answers) | |
26 | - | |
26 | + | |
27 | Console.WriteLine($"X{NumbX} == {a}"); | |
28 | - | |
28 | + | NumbX++; |
29 | - | Int16 i = 0; |
29 | + | |
30 | - | Console.WriteLine(dataName); |
30 | + | |
31 | - | foreach (var answer in answers) |
31 | + | |
32 | ||
33 | - | Console.WriteLine("x[{0}] = {1}",i,Math.Round(answer,3)); |
33 | + | |
34 | - | ++i; |
34 | + | |
35 | private static void InitialiseData(double[,] matrix, double[] sqrs, string[] data, int numberOfur) | |
36 | { | |
37 | for (int i = 1; i < numberOfur + 1; i++) | |
38 | { | |
39 | var dataInLine = data[i].Split().Select(x => double.Parse(x, CultureInfo.InvariantCulture)).ToArray(); | |
40 | for (int j = 0; j < numberOfur; j++) | |
41 | { | |
42 | matrix[i - 1, j] = dataInLine[j]; | |
43 | } | |
44 | sqrs[i - 1] = dataInLine[numberOfur]; | |
45 | } | |
46 | } | |
47 | ||
48 | private static double[] CalculateAnswers(double[,] mathrix, double[] sqrs, double determinant) | |
49 | { | |
50 | var answers = new double[sqrs.Length]; | |
51 | for (int i = 0; i < sqrs.Length; i++) | |
52 | { | |
53 | var cahce = new double[sqrs.Length]; | |
54 | for (int j = 0; j < sqrs.Length; j++) | |
55 | { | |
56 | cahce[j] = mathrix[j, i]; | |
57 | mathrix[j, i] = sqrs[j]; | |
58 | } | |
59 | var matrix = new double[sqrs.Length, sqrs.Length]; | |
60 | for (int a = 0; a < sqrs.Length; a++) | |
61 | for (int b = 0; b < sqrs.Length; b++) | |
62 | matrix[a, b] = mathrix[a, b]; | |
63 | answers[i] = CalculateDeterminat(matrix, new double[sqrs.Length]) / determinant; | |
64 | for (int j = 0; j < sqrs.Length; j++) | |
65 | { | |
66 | mathrix[j, i] = cahce[j]; | |
67 | } | |
68 | } | |
69 | return answers; | |
70 | } | |
71 | ||
72 | private static double CalculateDeterminat(double[,] matrix, double[] sqrs) | |
73 | { | |
74 | var determinant = matrix[0, 0]; | |
75 | var index = 0; | |
76 | while (index < sqrs.Length - 1) | |
77 | { | |
78 | for (int i = index; i < sqrs.Length - 1; i++) | |
79 | { | |
80 | var delitel = matrix[i + 1, index] / matrix[index, index]; | |
81 | for (int j = 0; j < sqrs.Length; j++) | |
82 | { | |
83 | matrix[i + 1, j] -= matrix[index, j] * delitel; | |
84 | ||
85 | } | |
86 | sqrs[i + 1] -= sqrs[index] * delitel; | |
87 | } | |
88 | index++; | |
89 | determinant *= matrix[index, index]; | |
90 | ||
91 | } | |
92 | return determinant; | |
93 | } | |
94 | } | |
95 | } |