Требуется найти все корни уравнения с точностью не ниже 10⁻¹².
Уравнение имеет вид
\displaystyle \sqrt{|x+3|}-\cos{(0.387x)}=0

Вот решение на PascalABCNET 3.3, сборка 1627 от 27.01.2018:

uses NumLibABC;

begin
var f:real->real:=x->Sqrt(Abs(x+3))-Cos(0.387*x);
var oL:=new RootsIsolation(f,-10,10,0.1);
var oZ:=new Zeroin(f,1e-12);
foreach var r in oL.Value do
oZ.Value(r[0],r[1]).Println
end.

Найдены корни
-3.1250285461067
-2.77171087522778

Интересует решение другим путем (назовем его "школьным" или "студенческим") на любом из языков Pascal, C/C++/C#, Basic.


Аноним: Полутора суток прошло, а желающих нет. Конечно, это чуть сложнее, чем находить сумму цифр в числе или заменять в массиве каждый второй элемент нулем. Но уважаемые, к чему тогда все эти олимпиады, на которые вы ходите и каких-то там высот добиваетесь, чему вас в вузах учат, если простую задачу, каких в математике сотни, вы решить не беретесь? Вот это и есть настоящий уровень ваших знаний и умений...
Аноним: Где же вы, Знатоки, ну покажите, что это звание больше, чем просто наклейка!
Аноним: А если кто-то думает, что я "прикрываюсь" в решении готовой библиотекой - извините, имею полное право, поскольку сам её и писал.
Exponena: Студентом бы я мог использовать метод "вилки" достаточно прост для реализации (когда-то и делал). Правда сначала требуется "изолировать" все корни. Для любого уравнения автоматический гарантированный поиск всех корней не представляю. Н вот конкретно это. Достаточно рассмотреть только отрезок, являющийся решением неравенства |x+3|<=1.
NaaMan: Приветствую тебя, уважаемый. С большой неохотой вынужден признать своё бессилие в решении этой задачи. За два дня я не смог побороть её. Моих знаний, действительно хватает только для нахождения суммы цифр числа (((
Аноним: Зато теперь Вы знаете, над чем работать)))))

Ответы

Ответ дал: Exponena
19
Ну раз никто не решился, а может не захотел возиться, покажу я вам динозавра!
У меня когда-то была программа на QBASIC. (Первая личный комп вначале был без жёсткого диска. Под DOS грузили с дискеты. И там этот мелкий интерпретатор (ок 190 кБайт) был неплохим подспорьем.)
 Программа сохранилась. Она изначально только график рисовала. Потом я её дополнял. В том числе и решением уравнений вилкой. Было несколько версий Функцию я по-быстрому заменил на  требуемую в задаче. Перелопачивать и выяснять полностью состояние программы не стал.
  За требуемую точность не поручусь. Но 4-6 знаков после запятой выдам. Это был "Полуавтоматический" вариант с прорисовкой графика. Красной линией прочерчивалась прямая y=0. График можно было перерисовывать, задавая новые пределы изменения переменной х. Глядя на график можно было определить исходные отрезки для запуска метода вилки.
На скринах, естественно, проблемы с кириллицей. (Ненастроенный DosBox) Но текст программы загнал в pdf. Там можно прочесть все надписи.

На 3-м снимке видно, что, потребовав точность 10^{-12}, я получил ответ, отличающийся от ответа МАСТЕРА. Я так думаю, что у меня не все переменные, требуемые для расчёта объявлены с двойной точностью. (Изначально таких там вообще не было). Но 7 знаков после запятой в ответе совпадают. :) А может это ограничение демоверсии QBASIC интерпретатора.

x_1 \approx -3,1203 \\  \\ x_2 \approx -2,77171


Приложения:

Exponena: Это понятно. Ладно, я хоть теперь знаю название алгоритма. При необходимости можно посмотреть хотя бы.
Аноним: Хотите - выложу Руководство на файловый ресурс и дам Вам ссылку.
Аноним: Там и ссылки на литературу есть)))
Exponena: Руководство поABC? Давайте
Аноним: Нет, не по АВС, лишь по БИБЛИОТЕКЕ
Аноним: Я не автор АВС )))
Exponena: Пусть так. Саму реализацию метода вы хотели предложить?
Аноним: Ушло в ЛС в силу запрета публикации ссылок на внешние ресурсы
Аноним: Нет, реализация в другом файле из комплекта поставки PascalABC.NET 3.3.
Аноним: Эта библиотека с ноября 2017 года считается частью официальной поставки пакета.
Вас заинтересует