• Najnowsze pytania
  • Bez odpowiedzi
  • Zadaj pytanie
  • Kategorie
  • Tagi
  • Zdobyte punkty
  • Ekipa ninja
  • IRC
  • FAQ
  • Regulamin
  • Książki warte uwagi

Obliczanie pierwiastka funkcji nieliniowej metodą siecznych

Object Storage Arubacloud
0 głosów
577 wizyt
pytanie zadane 4 grudnia 2016 w C i C++ przez orlicki12 Początkujący (450 p.)

Witam mam napisać program do liczenia jak w temacie. Sugerowałem się tym opisem tej metody. Wzór i wykres mojej funkcji jest taki:

Napisałem coś takiego ale program się w ogóle nie kończy jako że to dopiero początek mojej przygody z c++ więc pewnie popełniłem jakis elementarny błąd.

#include <stdio.h>
#include <math.h>
using namespace std;

double f(double x)
{ return (1+(3*(pow(x, 2.)))); }

int main() {
    double x=-2., y, xk[99];
    do
    { for(double x=-2.; x<=3.; x+=0.1)
    {
       for(int i=0; i<=98; i++)
        {
        xk[i-1]= f(x);
        xk[i+1]=xk[i]-(f(xk[i]*(xk[i]-xk[i-1])))/(f(xk[i]-f(xk[i-1])));
        printf("x=%f \n",xk[i-1]);
        }
    }
    }while (y>=0.00001);
   printf("Wyniki: x=%f \n",x );
   return 0;
}

Z góry dzięki za pomoc :D

1 odpowiedź

0 głosów
odpowiedź 4 grudnia 2016 przez niezalogowany
Wziąłeś pochodną do szukania pierwiastka... Ona nie ma miejsce zerowych :D
komentarz 4 grudnia 2016 przez orlicki12 Początkujący (450 p.)

hmm po wpisaniu tej wyżej jest to samo.

#include <stdio.h>
#include <math.h>
using namespace std;

double f(double x)
{ return (pow(x,3.)+x-3); }

int main() {
    double x=-2., y, xk[99];
    do
    { for(double x=-2.; x<=3.; x+=0.1)
    {
       for(int i=0; i<=98; i++)
        {
        xk[i-1]= f(x);
        xk[i+1]=xk[i]-(f(xk[i]*(xk[i]-xk[i-1])))/(f(xk[i]-f(xk[i-1])));
        printf("x=%f \n",xk[i-1]);
        }
    }
    }while (y>=0.00001);
   printf("Wyniki: x=%f \n",x );
   return 0;
}

 

komentarz 4 grudnia 2016 przez niezalogowany

Masz trochę przekombinowane z pętlami i tablicami. Na ekranie wypisuje się 100 razy to samo. Usunąłem pętlę for i zobacz ile mam wyników bez powtórzeń:
 

#include <stdio.h>
#include <math.h>
#include <windows.h>
using namespace std;

double f(double x)
{ return (pow(x,3.)+x-3); }

int main() {
    int i=0;
    double x=-2., y, xk[99];
    do
    { for(double x=1.; x<=3.; x+=0.1)
    {

        xk[i-1]= f(x);
        xk[i+1]=xk[i]-(f(xk[i]*(xk[i]-xk[i-1])))/(f(xk[i]-f(xk[i-1])));
        printf("x=%f \t %f \n",xk[i-1], f(xk[i-1]));


    }
    }while (y>=0.00001);
   printf("Wyniki: x=%f \n",x );
   return 0;
}

Ile wynosi y? Jest zadeklarowany, ale nic z nim nie robisz. Dlaczego nagle x jest z przedziału od -1 do 24? 

komentarz 4 grudnia 2016 przez orlicki12 Początkujący (450 p.)
rzeczywiście y został mi z poprzedniej wersji właśnie x powinien być z przedziału -2 do 3 jak na wykresie. A masz jakiś pomysł jak zrobić to żeby nie było przekombinowane z tablicami?
komentarz 4 grudnia 2016 przez niezalogowany
Np. tak: http://eff10.internetdsl.tpnet.pl/programowanie/mz_fun/pages/regulafalsi.htm

Najlepiej jakbyś kierował początkiem, a nie gotowym kodem.

Podobne pytania

0 głosów
2 odpowiedzi 324 wizyt
pytanie zadane 3 grudnia 2016 w C i C++ przez orlicki12 Początkujący (450 p.)
0 głosów
2 odpowiedzi 636 wizyt
pytanie zadane 15 lutego 2017 w Matematyka, fizyka, logika przez Bakr Mądrala (6,850 p.)
0 głosów
1 odpowiedź 276 wizyt
pytanie zadane 13 listopada 2016 w C i C++ przez orlicki12 Początkujący (450 p.)

92,575 zapytań

141,424 odpowiedzi

319,649 komentarzy

61,960 pasjonatów

Motyw:

Akcja Pajacyk

Pajacyk od wielu lat dożywia dzieci. Pomóż klikając w zielony brzuszek na stronie. Dziękujemy! ♡

Oto polecana książka warta uwagi.
Pełną listę książek znajdziesz tutaj.

Akademia Sekuraka

Kolejna edycja największej imprezy hakerskiej w Polsce, czyli Mega Sekurak Hacking Party odbędzie się już 20 maja 2024r. Z tej okazji mamy dla Was kod: pasjamshp - jeżeli wpiszecie go w koszyku, to wówczas otrzymacie 40% zniżki na bilet w wersji standard!

Więcej informacji na temat imprezy znajdziecie tutaj. Dziękujemy ekipie Sekuraka za taką fajną zniżkę dla wszystkich Pasjonatów!

Akademia Sekuraka

Niedawno wystartował dodruk tej świetnej, rozchwytywanej książki (około 940 stron). Mamy dla Was kod: pasja (wpiszcie go w koszyku), dzięki któremu otrzymujemy 10% zniżki - dziękujemy zaprzyjaźnionej ekipie Sekuraka za taki bonus dla Pasjonatów! Książka to pierwszy tom z serii o ITsec, który łagodnie wprowadzi w świat bezpieczeństwa IT każdą osobę - warto, polecamy!

...