lab08

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Text.RegularExpressions;
namespace lab08
{
public delegate double Del(double A, double B, double Accuracy);
class Program
{
static void Main(string[] args)
{
foreach (string arg in args)
if (arg == "-a")
{
Console.WriteLine("Лабораторная работа №8\n" +
"Напишите функцию, которая находит корень уравнения методом дихотомии.\n" +
"Аргументами функции являются границы интервала, на котором находится корень,\n" +
"делегат, связанный с уравнением, и точность, с которой корень необходимо найти\n" +
"\nГруппа: 5-ПМИ-095\nСделал: Дубровский Николай\n" +
"Нажмите что-нибудь, чтобы продолжить работу");
Console.ReadLine();
Console.Clear();
}
string A, B, Accuracy;
Console.WriteLine("Левая граница интервала");
A = Console.ReadLine();
Console.WriteLine("Правая граница интервала");
B = Console.ReadLine();
Console.WriteLine("Точность вычисления");
Accuracy = Console.ReadLine();
string[] StringToCheck = new string[3] { A, B, Accuracy };
IsValid(ref StringToCheck);
Del Ob = new Del(Function);
Double a = Convert.ToDouble(A), b = Convert.ToDouble(B), c = Convert.ToDouble(Accuracy);
Console.WriteLine("Решение уравнения x = {0}", Ob(a, b, c));
}
static double Function(double A, double B, double Accuracy)
{
double C = 0.0;
while (B - A > Accuracy)
{
C = (A + B) / 2;
if (f(A) * f(C) < 0) //f(C) > 0
B = C;
else
A = C;
}
return (A + B) / 2;
}
static double f(double x)
{
return x * x + Math.Pow(Math.E, x) - 2;
//return 4 - Math.Pow(Math.E, x) - 2 * x * x;
}
static void IsValid(ref string[] Values)
{
for(int i=0; i!= Values.Length; ++i)
{
while (!Regex.IsMatch(Values[i], @"(^(\+|-)?[0-9]{1,}[,]{1}[0-9]{1,}$)|(^(\+|-)?[0-9]{1,}$)"))
{
string some = "Неверный ввод, введите еще раз";
switch (i)
{
case 0: some += " левую границу интервала";
break;
case 1: some += " правую границу интервала";
break;
case 2: some += " точность вычисления";
break;
}
Console.WriteLine(some);
Values[i] = Console.ReadLine();
}
}
}
}
}