Форум программистов, компьютерный форум, киберфорум
Наши страницы

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
 
Рейтинг: Рейтинг темы: голосов - 62, средняя оценка - 4.69
OffSide
2 / 2 / 0
Регистрация: 03.10.2010
Сообщений: 111
#1

Схема Горнера - C++

15.11.2010, 23:22. Просмотров 8189. Ответов 57
Метки нет (Все метки)

код схемы Горнера
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
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
/*
 * 6
 * 3
 * 1 3 -2 1 -1 1
 *
 * Ответ: 439
 */
 
#include <stdlib.h>     /** EXIT_FAILURE **/
#include <iostream>
using namespace std;
 
int main( int argc, char *argv[] )
{
    register unsigned int i;
    unsigned int n;
    cout << "Введите количество элементов: ";
    cin >> n;
 
    if ( n < 1 )
    {
        cerr << "Требуется хотя бы два элемента." << endl;
        return EXIT_FAILURE;
    }
 
    double *a = new double [n];
    double *b = new double [n];
 
    cout << "Введите эпсилон: ";
    double eps; cin >> eps;
 
    cout << "Введите " << n << " исходн. элем.:" << endl;
    for ( i = 0; i < n; i++ ) cin >> a[i];
 
    cout << endl;
 
    /* Рисуем верхнюю рамку */
    for ( i = 0; i < n; i++ ) cout << "+-------"; cout << "+" << endl;
 
    /* Выводим исходные элементы */
    for ( i = 0; i < n; i++ ) cout << "| " << a[i] << "\t"; cout << "|" << endl;
 
    /* Снова рамка */
    for ( i = 0; i < n; i++ ) cout << "+-------"; cout << "+" << endl;
 
    /* По условию, первый элемент b равен первому элементу a */
    b[0] = a[0];
    cout << "| " << *b << "\t";
    for( i = 1; i < n; i++ )
    {
        b[i] = b[i - 1] * eps;
        /* В этом месте b[i] будет равно значению, записываемому во вторую строчку */
        b[i] += a[i];
        cout << "| " << b[i] << "\t";
    }
    cout << "+" << endl;
 
    /* И ещё одна завершающая рамка */
    for ( i = 0; i < n; i++ ) cout << "+-------"; cout << "+" << endl << endl;
    cout << "Ответ: " << b[n-1] << endl;
 
    delete []b;
    delete []a;
    return 0;
}
программа на С++, как можно под БорландС переделать.

общаяя задача: Исследование уравнения. Даны натуральное число n и целые числа f0, ... , fn. Исследовать существование целочисленных корней уравнения f0*x^n+f1*x^(n-1)+...+fn=0. Если fn=0, то имеется корень, равный 0; если же fn!=0, то целочисленный корень, если он существует, принадлежит конечному множеству положительных и отрицатльных делителей числа fn. Здесь следует определить подпрограмму, которая по двум заданным числам k и m (m>k>=0) позволяет определить значение наименьшего делителя числа m, превышающего k, а так же подпрограмму вычисления значения многочлена по схеме Горнера : y=(...((f0*x+f1)*x+f2)*x+...+f(n-1)*x+fn

Добавлено через 5 часов 33 минуты
препод будет меня жеско иметь)))
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
15.11.2010, 23:22
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Схема Горнера (C++):

Схема горнера - C++
Эта схема основывается на следующем представлении многочлена: p(x) = (( ... ((an*x + an-1)x + an-2)x + ... + a2)x + a1)x + a0 ...

Схема Горнера( - C++
Всем привет, друзья, очень нуждаюсь в вашей помощи.. Я чайник в C++. Очень нужно решить задачу, буду премного благодарен:

Схема Горнера - C++
Дан многочлен P(x)=anxn + an−1xn−1+ … + a1x + a0 и число x. Вычислите значение этого многочлена, воспользовавшись схемой Горнера: ...

Схема Горнера - C++
Дано вещественное целое число x, целое n, n&gt;0. Найти значение многочлена n-й степени P(x) в точке x по схеме Горнера:...

Рекурсия. Схема Горнера. - C++
Вот собственно задача. Я вообще не понимаю как её решать=( Вычислить по формуле Горнера значение многочлена a0xn + + a1xn-1 +…+...

схема Горнера (помогите с курс. работой) - C++
#include&lt;iostream&gt; #include &lt;conio.h&gt; using namespace std; #define n 1 int main() { float x, b, a; int...

57
silent_1991
Эксперт С++
4989 / 3046 / 149
Регистрация: 11.11.2009
Сообщений: 7,028
Завершенные тесты: 1
17.11.2010, 19:33 #16
Что такое Борланд? Что такое Си++?
0
OffSide
2 / 2 / 0
Регистрация: 03.10.2010
Сообщений: 111
17.11.2010, 19:52  [ТС] #17
эмм.. учитель, как вы уже говорили. С++ это язык программирования, а борланд это среда разработки, которая использует компилятор языка С++.

возьмем пару определений из гугла.

C++ — компилируемый статически типизированный язык программирования общего назначения. Поддерживая разные парадигмы программирования, сочетает свойства как высокоуровневых, так и низкоуровневых языков. В сравнении с его предшественником — языком C, — наибольшее внимание уделено поддержке объектно-ориентированного и обобщённого программирования.

Borland C++— среда программирования (IDE) на языках Си и C++ для DOS, Windows и Windows NT. Потомок Turbo C. Его отладчик Turbo Debugger был написан для защищённого режима DOS.
0
silent_1991
Эксперт С++
4989 / 3046 / 149
Регистрация: 11.11.2009
Сообщений: 7,028
Завершенные тесты: 1
17.11.2010, 19:59 #18
И что из этого следует? Ваш вопрос можно перефразировать так: "Как переделать программу, написанную на языке программирования под среду разработки?" И что, по-вашему, на это надо ответить?
Короче так, сформулируйте вопрос нормально, а то нам за эту полемику, которая скоро на две страницы растянется, влепят по преду и на этом всё кончится...
0
OffSide
2 / 2 / 0
Регистрация: 03.10.2010
Сообщений: 111
17.11.2010, 20:01  [ТС] #19
хорошо, представим, что я не выкладывал схему горнера на С++, а напишу проще : "ребята, помогите решить задачу": Исследование уравнения. Даны натуральное число n и целые числа f0, ... , fn. Исследовать существование целочисленных корней уравнения f0*x^n+f1*x^(n-1)+...+fn=0. Если fn=0, то имеется корень, равный 0; если же fn!=0, то целочисленный корень, если он существует, принадлежит конечному множеству положительных и отрицатльных делителей числа fn. Здесь следует определить подпрограмму, которая по двум заданным числам k и m (m>k>=0) позволяет определить значение наименьшего делителя числа m, превышающего k, а так же подпрограмму вычисления значения многочлена по схеме Горнера : y=(...((f0*x+f1)*x+f2)*x+...+f(n-1)*x+fn

на борланде, буду очень признателен
0
archinko
14 / 14 / 2
Регистрация: 02.03.2010
Сообщений: 29
17.11.2010, 20:27 #20
Цитата Сообщение от OffSide Посмотреть сообщение
хорошо, представим, что я не выкладывал схему горнера на С++, а напишу проще : "ребята, помогите решить задачу": Исследование уравнения. Даны натуральное число n и целые числа f0, ... , fn. Исследовать существование целочисленных корней уравнения f0*x^n+f1*x^(n-1)+...+fn=0. Если fn=0, то имеется корень, равный 0; если же fn!=0, то целочисленный корень, если он существует, принадлежит конечному множеству положительных и отрицатльных делителей числа fn. Здесь следует определить подпрограмму, которая по двум заданным числам k и m (m>k>=0) позволяет определить значение наименьшего делителя числа m, превышающего k, а так же подпрограмму вычисления значения многочлена по схеме Горнера : y=(...((f0*x+f1)*x+f2)*x+...+f(n-1)*x+fn
на борланде, буду очень признателен
Да не вопрос, вот держи :
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
50
51
52
53
54
55
56
57
#include <stdlib.h>
#include <iostream>
using namespace std;
 
int main( int argc, char *argv[] )
{
        register unsigned int i;
        unsigned int n;
        cout << "Введите количество элементов: ";
        cin >> n;
 
        if ( n < 1 )
        {
                cerr << "Требуется хотя бы два элемента." << endl;
                return EXIT_FAILURE;
        }
 
        double *a = new double [n];
        double *b = new double [n];
 
        cout << "Введите эпсилон: ";
        double eps; cin >> eps;
 
        cout << "Введите " << n << " исходн. элем.:" << endl;
        for ( i = 0; i < n; i++ ) cin >> a[i];
 
        cout << endl;
 
        /* Рисуем верхнюю рамку */
        for ( i = 0; i < n; i++ ) cout << "+-------"; cout << "+" << endl;
 
        /* Выводим исходные элементы */
        for ( i = 0; i < n; i++ ) cout << "| " << a[i] << "\t"; cout << "|" << endl;
 
        /* Снова рамка */
        for ( i = 0; i < n; i++ ) cout << "+-------"; cout << "+" << endl;
 
        /* По условию, первый элемент b равен первому элементу a */
        b[0] = a[0];
        cout << "| " << *b << "\t";
        for( i = 1; i < n; i++ )
        {
                b[i] = b[i - 1] * eps;
                /* В этом месте b[i] будет равно значению, записываемому во вторую строчку */
                b[i] += a[i];
                cout << "| " << b[i] << "\t";
        }
        cout << "+" << endl;
 
        /* И ещё одна завершающая рамка */
        for ( i = 0; i < n; i++ ) cout << "+-------"; cout << "+" << endl << endl;
        cout << "Ответ: " << b[n-1] << endl;
 
        delete []b;
        delete []a;
        return 0;
}
2
OffSide
2 / 2 / 0
Регистрация: 03.10.2010
Сообщений: 111
17.11.2010, 22:06  [ТС] #21
можно вкратце объяснения хоть какое-нибудь
0
OffSide
2 / 2 / 0
Регистрация: 03.10.2010
Сообщений: 111
21.11.2010, 12:01  [ТС] #22
как балаболить , так все горазды, а как помочь, так никто
0
silent_1991
Эксперт С++
4989 / 3046 / 149
Регистрация: 11.11.2009
Сообщений: 7,028
Завершенные тесты: 1
21.11.2010, 12:41 #23
Ладно, тогда продолжим балаболить.
Честное слово, я уже устал задавать этот вопрос, но придётся снова это сделать: скажите наконец, что вам не ясно?
0
OffSide
2 / 2 / 0
Регистрация: 03.10.2010
Сообщений: 111
21.11.2010, 12:51  [ТС] #24
Ничего не понятно, читаю книги, методички, но не могу вникнуть и составить такие сложные программы.. только когда мне помогут, я начинаю понимать, иду к преподу , он начинает меня расспрашивать каждую букву/слово в программе, и через 10 минут. я понимаю, что программу можно было написать за 30 минут и все так просто
0
silent_1991
Эксперт С++
4989 / 3046 / 149
Регистрация: 11.11.2009
Сообщений: 7,028
Завершенные тесты: 1
21.11.2010, 13:01 #25
Так вы конкретно спрашивайте. Вот вы выложили код. И начали твердить, что не можете его переделать под Borland C++. Я вам 3 раза сказал, что ничего переделывать не надо, всё и так готово. На третий раз вы, вроде бы, поняли меня. Но нет, потом опять попросили выложить код на борланде. Человек решил постебаться и дал вам ваш же код, скопированный из первого поста. Вы наконец-таки продвинулись дальше - попросили "объяснения хоть какое-нибудь" (с). Т.е. сразу этого объяснения попросить было нельзя, надо было подождать, пока тема на растянется больше, чем на одну страницу.
ОК, теперь я спрашиваю вас - что именно вам не понятно. Но вы отвечаете, что вам ничего не понятно. И что мы, которые стараются всеми силами помочь вам, должны на это отвечать? Как вам помогать? Пока вы не конкретизируете вопрос (пусть будет длинный список, но список вопросов, а не заявления "мне ничего не понятно") - помочь вам мы будем не в состоянии, и отнюдь не из нашей вредности.
0
OffSide
2 / 2 / 0
Регистрация: 03.10.2010
Сообщений: 111
21.11.2010, 13:05  [ТС] #26
этот код, который я воложил, он на с++ работает, а на борланде кучу ошибок выдает)
0
silent_1991
Эксперт С++
4989 / 3046 / 149
Регистрация: 11.11.2009
Сообщений: 7,028
Завершенные тесты: 1
21.11.2010, 13:06 #27
Хоть что-то. Какие ошибки? Телепаты дружно смотались в Турцию, так что давайте текст ошибок.
0
OffSide
2 / 2 / 0
Регистрация: 03.10.2010
Сообщений: 111
21.11.2010, 13:07  [ТС] #28
http://codepad.org/M1gy8APd
0
silent_1991
Эксперт С++
4989 / 3046 / 149
Регистрация: 11.11.2009
Сообщений: 7,028
Завершенные тесты: 1
21.11.2010, 13:08 #29
Расширение файла какое? Если *.c - поменяйте на *.cpp
0
OffSide
2 / 2 / 0
Регистрация: 03.10.2010
Сообщений: 111
21.11.2010, 13:30  [ТС] #30
я проверяю только на этом сайте, ибо 7 стоит, и с++ не работает, поэтому поменять не могу
0
21.11.2010, 13:30
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
21.11.2010, 13:30
Привет! Вот еще темы с ответами:

Полином по правилу Горнера - C++
Здравствуйте ребят, помогите с задачкой, пожалуйста? Плохо знаю С++, желательно на начальном уровне написать код. &quot;Посчитать значение...

Алгоритм схемы Горнера - C++
Задача такова: необходимо посчитать Сумму произведения ((-1)^k)*(((x/2)^2k)/((k!)^2)), где k изменяеться от 1 до бесконечности. Мною...

Правильно ли я разложил по схеме Горнера? - C++
Было задание разложить многочлен по схеме Горнера с использованием рекурсии. Вопрос в том, правильно ли я разложил? Формула x+3-e^-x ...

Рассчитать значение переменной по схеме Горнера - C++
задание по схеме Горнера : как это делать? неврублюсь Оффициальным языком форума является русский язык. В дальнейшем Ваши темы...


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

Или воспользуйтесь поиском по форуму:
30
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.