Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.54/13: Рейтинг темы: голосов - 13, средняя оценка - 4.54
 Аватар для Kuzia domovenok
4268 / 3327 / 926
Регистрация: 25.03.2012
Сообщений: 12,536
Записей в блоге: 1

Решение куб. уравнения.

27.04.2012, 21:59. Показов 2658. Ответов 1
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
решение кубического уравнения.
Программа работает слишком медленно. (Не знаю в каком месте медленно, как по мне - так нормально)
Есть кубическое уравнение вида A*X3 + B*X2 + C*X + D = 0. все корни уравнений – целые числа и находятся на отрезке [-100, 100]. написать программу, которая поможет ему найти корни кубических уравнений!
Я пишу так.
Как известно, целочисленные корни уравнения являются делителями свободного члена (или что-то в этом роде, не помню). Так вот.
Если D=0, сначала вывожу 0 и отбрасываю нулевые корни. Затем беру в качестве свободного члена последний ненулевой коэффициент.
В цикле нахожу все его делители j, меньшие или равные корню из свободного члена (while (j*j<=N)){if(N%j==0){...}j++;}
заношу их в массив d[].
парные им делители будут N/d[]
И, наконец, в цикле проверяю числа -N/d[i], -d[i], d[i], N/d[i] , нет ли среди них корней уравнения.
Разве это не оптимальный алгоритм? Но мне сказали, что не проходит какой-то "тест" по времени.
Есть идеи в чём проблема? Считает всё правильно и шустро.
C++
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
#include <stdio.h>
int i, N, sz, j;
int a[4]={0};
int d1[10], d2[10];
inline int test(int x){
    return x*x*x*a[0]+x*x*a[1]+x*a[2]+a[3];
}
 
int main(){//19:02 27.04 not shown
    freopen("INPUT.TXT", "r", stdin);
    freopen("OUTPUT.TXT", "w", stdout);
    scanf("%d %d %d %d", a, a+1, a+2, a+3);
    i=3;
    if (!a[3]){
        printf("0 ");
        while((!a[i])&&i)
            i--;
        if (!i) 
            return 0;
    }
    N=(a[i]>0)?a[i]:-a[i];
    sz=0; j=2;
    d1[0]=1; 
    while((j*j<=N)&&(j<=100)){
        if ((N%j)==0){
            sz++;
            d1[sz]=j;//root
            d2[sz]=N/j;
        }
        j++;
    }
    if ((j-1)*(j-1)==N){d2[sz]=N+1;}
    for(j=0; j>=sz; j++){
        if(test(-d2[j])==0)
            printf("%d ", -d2[j]);
    }
    for(j=sz; j>=0; j--){
        if(test(-d1[j])==0)
            printf("%d ", -d1[j]);
    }
    for(j=0; j<=sz; j++){
        if(test(d1[j])==0)
            printf("%d ", d1[j]);
    }
    for(j=sz; j>=0; j--){
        if(test(d2[j])==0)
            printf("%d ", d2[j]);
    }
}
1
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
27.04.2012, 21:59
Ответы с готовыми решениями:

Куб модуля произведения наибольшего и наименьшего корней кубического уравнения
Помогите решить Куб модуля произведения наибольшего и наименьшего корней кубического уравнения x3−2x2−11x+12=0 считать...

Определить тип уравнения, указать метод решения, общее решение дифференциального уравнения
дано дифференциальное уравнение первого порядка: (x+y+1)dx+(x-y2+3)dy=0. Определить тип уравнения, указать метод решения, общее решение...

Алгоритмизация решения уравнения для банковского IT-шника (или просто решение уравнения)
Добрый день. Нужна помощь (в идеале) с алгоритмизацией решения уравнения или (тоже отлично) способом численного решения уравнения для...

1
 Аватар для UFO94
267 / 256 / 23
Регистрация: 04.04.2012
Сообщений: 546
27.04.2012, 22:19
Ну, мне кажется, что нужно найти только 1 корень, а потом облегчить работу компьютеру своим мозгом, решив квадратное уравнение аналитически -- дискриминант и т.д.

Не по теме:

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

0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
27.04.2012, 22:19
Помогаю со студенческими работами здесь

Найти общее решение или частное решение уравнения первого порядка
Помогите решить: 2*x*sqrt(1-y^2)=y' * (1+x^2). Я не понимаю как решить это, т.к. dx и dy получаются в знаменателе...

Найти решение уравнения, изоклинную и интегральную кривые, решение задачи Коши
Помогите пожалуйста! а) Найти решение вида: x=a,y=b,y=kx+b y'=\frac{y^2-4}{xy},\\ y'=x-y+2 б) Какая кривая является одновременно...

Найти общее решение дифференциального уравнения II порядка и частное решение.
помоги пожалуйста!!! Найти общее решение дифференциального уравнения II порядка и частное решение, удовлетворяющее указанным начальным...

Найти общее решение дифференциального уравнения I порядка и частное решение.
помогите пожалуйста!!!! Найти общее решение дифференциального уравнения I порядка и частное решение, удовлетворяющее указанным начальным...

Найти общее решение дифференциального уравнения и частное решение, удовлетворяющее начальному условию
y={y}_{0} при x={x}_{0},y(0)=1 y'-3x^2y={e}^{2x+x^3} y=uv y'=u'v+uv' u'v+uv'-3x^2uv={e}^{2x+3}


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
Как дизайн сайта влияет на конверсию: 7 решений, которые реально повышают заявки
Neotwalker 08.03.2026
Многие до сих пор воспринимают дизайн сайта как “красивую оболочку”. На практике всё иначе: дизайн напрямую влияет на то, оставит человек заявку или уйдёт через несколько секунд. Даже если у вас. . .
Модульная разработка через nuget packages
DevAlt 07.03.2026
Сложившийся в . Net-среде способ разработки чаще всего предполагает монорепозиторий в котором находятся все исходники. При создании нового решения, мы просто добавляем нужные проекты и имеем. . .
Модульный подход на примере F#
DevAlt 06.03.2026
В блоге дяди Боба наткнулся на такое определение: В этой книге («Подход, основанный на вариантах использования») Ивар утверждает, что архитектура программного обеспечения — это структуры,. . .
Управление камерой с помощью скрипта OrbitControls.js на Three.js: Вращение, зум и панорамирование
8Observer8 05.03.2026
Содержание блога Финальная демка в браузере работает на Desktop и мобильных браузерах. Итоговый код: orbit-controls-threejs-js. zip. Сканируйте QR-код на мобильном. Вращайте камеру одним пальцем,. . .
SDL3 для Web (WebAssembly): Синхронизация спрайтов SDL3 и тел Box2D
8Observer8 04.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-sync-physics-sprites-sdl3-c. zip На первой гифке отладочные линии отключены, а на второй включены:. . .
SDL3 для Web (WebAssembly): Идентификация объектов на Box2D v3 - использование userData и событий коллизий
8Observer8 02.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-collision-events-sdl3-c. zip Сканируйте QR-код на мобильном и вы увидите, что появится джойстик для управления главным героем. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru