Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
 
Рейтинг 4.69/16: Рейтинг темы: голосов - 16, средняя оценка - 4.69
0 / 0 / 0
Регистрация: 05.09.2011
Сообщений: 13

Перебор значений double

05.09.2011, 02:14. Показов 3476. Ответов 30
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Привет всем, весь день сижу и думаю над алгоритмом следующего

Нам известна функция которая принимает один параметр типа double и возвращает double.

Реализация функции неизвестна, но известны некоторые особенности:
  1. При вызове функции с параметром 0.0, мы получим число меньше нуля
  2. При вызове функции с параметром 1.0, мы получим число больше нуля
  3. Есть лишь единственное значение Х, между 0.0 и 1.0, при которых функция вернет 0

  • Цель - написать функцию перебора чисел от 0.0 до 1.0 чтобы найти при каком значение Х мы получим 0 из функции о которой писалось выше.


Естественно, double - число довольно здоровое, и хотя мы ограничены определенным диапозоном, у нас всеравно остается куча вариантов для перебора.. [0.000000000000001 ; 0.999999999999999] Простой перебор, увеличение Х на 0.000000000000001 в цикле, займет вечность, хотя и будет самым точным..

Пробовал ограничить кол-во перебора с помощью нахождения Х-а при котором передаваемый параметр был минимальным, но так и не придуал как это граммотно реализовать. Выходило что ограничить мог не так и сильно, либо получал не те результаты..

Можетбыть кто знает какие способы по скоращению времени на перебор в данном случае? Или куда глядеть дальше по этой теме?
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
05.09.2011, 02:14
Ответы с готовыми решениями:

Ошибки error C2296: -: недопустимо, левый операнд имеет тип "double (__cdecl *)(double,double,double
Думаю из-за polp #include<iostream> #include<cmath> #include<cstdlib> using namespace std; double polp(double af,double...

Ошибка: error LNK2001: unresolved external symbol "double __cdecl Akk(double,double,double)"
#include <iostream> #include <cmath> using namespace std; double Akk(double x, double y, double z); int main() { int a, b, c; ...

перебор значений
Вывести на экран в возрастающем порядке все трехзначные числа, в десятичной записи которых нет одинаковых цифр.

30
Каратель
Эксперт С++
6610 / 4029 / 401
Регистрация: 26.03.2010
Сообщений: 9,273
Записей в блоге: 1
05.09.2011, 02:31
Метод половинного деления
1
3 / 3 / 2
Регистрация: 27.07.2011
Сообщений: 13
05.09.2011, 02:38
Метод_половинного_деления
А кто сказал, что функция выдает непрерывно возрастающие значения?
Может перебирать все варианты начиная из нескольких мест сразу(например с начала и с конца),
так вероятность, что попадется быстрее выше.
0
0 / 0 / 0
Регистрация: 05.09.2011
Сообщений: 13
05.09.2011, 02:51  [ТС]
Перебор с двух концов идея не плохая, однако сокращение во времени тут будет зависеть от параметра.

Если параметр при котором функция вернет 0 находится в середине диапозона 0.0.....1 - 0.(9) то мы ничего не сократим.

С другой стороны если оно на начале 0.0....1 или в конце диапозона, тогда сократим.


Однако, не думаю что сокращение по времени будет большим.
0
Эксперт С++
 Аватар для grizlik78
2382 / 1666 / 279
Регистрация: 29.05.2011
Сообщений: 3,402
05.09.2011, 02:52
Цитата Сообщение от 5ANDR0 Посмотреть сообщение
А кто сказал, что функция выдает непрерывно возрастающие значения?
А монотонность (то есть непрерывное возрастание) для половинного деления и не требуется. Главное, чтобы функция меняла знак только один раз, проходя через ноль. Если функция может менять знак сколько угодно раз (очевидно, имея множество разрывов), то задача в общем случае нерешаема.
0
0 / 0 / 0
Регистрация: 05.09.2011
Сообщений: 13
05.09.2011, 02:57  [ТС]
Забыл написать, функция математически непрерывная. Значит меняет знак один раз.

Значит судя по сообщениям, следует попробовать Метод половинного деления, попробую утрецом, отпишусь.
0
Эксперт С++
 Аватар для grizlik78
2382 / 1666 / 279
Регистрация: 29.05.2011
Сообщений: 3,402
05.09.2011, 03:00
Раз она непрерывна и проходит через ноль только один раз, то и знак меняет только один раз. Так что метод половинного деления — это как раз то, что позволит очень быстро приблизиться вплотную к искомому значению.
1
0 / 0 / 0
Регистрация: 05.09.2011
Сообщений: 13
05.09.2011, 03:02  [ТС]
Думаете она сможет относительно быстро перебрать этот диапозон?

В любом случае, пошел читать про этот метод.
0
Эксперт С++
 Аватар для grizlik78
2382 / 1666 / 279
Регистрация: 29.05.2011
Сообщений: 3,402
05.09.2011, 03:05
Не больше, чем за 64 итерации А на самом деле даже меньше.
1
05.09.2011, 03:28

Не по теме:

Цитата Сообщение от Amell Посмотреть сообщение
Забыл написать, функция математически непрерывная. Значит меняет знак один раз.
Это утверждение справедливо для монотонных функций.

0
0 / 0 / 0
Регистрация: 05.09.2011
Сообщений: 13
05.09.2011, 03:33  [ТС]
Написал, работает!
Спасибо огромное!

Осталось теперь попроверять точность с несколькими разными уравнениями подходящими под описание, но посложнее чем то что я там понаписал для тестов, есть варианты?
0
Эксперт С++
 Аватар для grizlik78
2382 / 1666 / 279
Регистрация: 29.05.2011
Сообщений: 3,402
05.09.2011, 03:33
Цитата Сообщение от kazak Посмотреть сообщение
Это утверждение справедливо для монотонных функций.
Это, конечно, так, но если условие 3 относится именно к реализации, а не к математической функции, то задача снова становится нерешаемой в общем случае. Если же условие всё-так означает, что сама математическая функция проходит через ноль только один раз, то вместе с непрерывностью это гарантирует единственную смену знака.
0
 Аватар для alkagolik
1599 / 622 / 113
Регистрация: 15.07.2011
Сообщений: 3,548
05.09.2011, 03:34
это конечно правильно, но ведь
Реализация функции неизвестна
как же тогда проверять значения функции на знак? Подставим x=1/2... а куда подставим?
0
0 / 0 / 0
Регистрация: 05.09.2011
Сообщений: 13
05.09.2011, 03:35  [ТС]
kazak, значит решение данной задачи с помощью этого метода не может гарантировать в итоге решение для всех функций и присутвуют исключения?

Вообще запутался...
0
Эксперт С++
 Аватар для grizlik78
2382 / 1666 / 279
Регистрация: 29.05.2011
Сообщений: 3,402
05.09.2011, 03:40
Цитата Сообщение от Amell Посмотреть сообщение
Реализация функции неизвестна, но известны некоторые особенности:
Это особенности реализации или самой функции?
0
0 / 0 / 0
Регистрация: 05.09.2011
Сообщений: 13
05.09.2011, 03:45  [ТС]
Вобщем есть некая функция:

double d_Function(double X);

Мы не знаем ничего про само тело функции. Нам лишь известно следующее:
  1. d_Function математически непрерывная функция
  2. При d_Function(0.0f), return из функции выйдет < 0
  3. При d_Function(1.0f), return из функции выйдет > 0
  4. Есть лишь одно значение Х, при которых return из функции = 0.0f
0
 Аватар для alkagolik
1599 / 622 / 113
Регистрация: 15.07.2011
Сообщений: 3,548
05.09.2011, 03:48
дизассемблер, дебаггер и узнать функцию. иначе перебор (и то... как?). Или есть возможность кормить ей переменные? Если есть, то деление пополам лучший вариант (я так думаю)
0
0 / 0 / 0
Регистрация: 05.09.2011
Сообщений: 13
05.09.2011, 03:49  [ТС]
узнать функцию к сожалению невозможно
0
Эксперт С++
 Аватар для grizlik78
2382 / 1666 / 279
Регистрация: 29.05.2011
Сообщений: 3,402
05.09.2011, 03:52
Всё чудесатее и чудесатее (C)
Числа 1.0f и 0.0f имеют тип float. При этом аргумент и результат функций объявлены как double. По-моему кто-то хочет нас запутать

Цитата Сообщение от alkagolik Посмотреть сообщение
дизассемблер, дебаггер и узнать функцию. иначе перебор
Чтобы перебрать все числа double на отрезке (0.0, 1.0) потребуется очень быстрый вычислитель и очень много времени. Ну или очень много удачи
0
0 / 0 / 0
Регистрация: 05.09.2011
Сообщений: 13
05.09.2011, 03:54  [ТС]
Пардонте, там не флоат (без f), привычка так записывать числа с плав точкой просто

Тобишь, метод половинного деления будет работать только елси математически функция монотонная, я правильно понял? Попытаюсь тогда разузнать, монотонна она или нет.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
05.09.2011, 03:54
Помогаю со студенческими работами здесь

Перебор значений
Комрады, как мне заставить программу подбирать значение х и у не только парные (если х=1, то и у будет = 1), но и перебирать значения? ...

Перебор значений
Вывести на экран в возрастающем порядке все трехзначные числа, в десятичной записи которых нет одинаковых цифр.

Перебор и сравнение значений
Добрый день. Столкнулся с проблемой перебора. Есть входные данные и массив с константами. Требуется входные данные сравнить с константами и...

Перебор действительных значений в цикле
Ребят, вот только начал изучать с++ и сразу же возник вопрос. Есть X-начальное и X-конечное, как создать цикл или же перебрать все...

Перебор возможных значений для трёх чисел
Доброго времени суток. Нужно перебрать все возможные значения трёх чисел. их сума равна 1. перебрать нужно с шагом 0,01, например 0,01...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
20
Ответ Создать тему
Новые блоги и статьи
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод. Thinkpad X220 Tablet —. . .
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru