Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Prova GeForce NOW upgrade Blackwell: il cloud gaming cambia per sempre
Prova GeForce NOW upgrade Blackwell: il cloud gaming cambia per sempre
L'abbonamento Ultimate di GeForce NOW ora comprende la nuova architettura Blackwell RTX con GPU RTX 5080 che garantisce prestazioni tre volte superiori alla precedente generazione. Non si tratta solo di velocità, ma di un'esperienza di gioco migliorata con nuove tecnologie di streaming e un catalogo giochi raddoppiato grazie alla funzione Install-to-Play
Ecovacs Deebot X11 Omnicyclone: niente più sacchetto per lo sporco
Ecovacs Deebot X11 Omnicyclone: niente più sacchetto per lo sporco
Deebot X11 Omnicyclone implementa tutte le ultime tecnologie Ecovacs per l'aspirazione dei pavimenti di casa e il loro lavaggio, con una novità: nella base di ricarica non c'è più il sacchetto di raccolta dello sporco, sostituito da un aspirapolvere ciclonico che accumula tutto in un contenitore rigido
Narwal Flow: con il mocio orizzontale lava i pavimenti al meglio
Narwal Flow: con il mocio orizzontale lava i pavimenti al meglio
Grazie ad un mocio rotante che viene costantemente bagnato e pulito, Narwal Flow assicura un completo e capillare lavaggio dei pavimenti di casa. La logica di intellignza artificiale integrata guida nella pulizia tra i diversi locali, sfruttando un motore di aspirazione molto potente e un sistema basculante per la spazzola molto efficace sui tappeti di casa
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 26-04-2007, 19:13   #1
dengel_1
Member
 
Iscritto dal: Feb 2007
Messaggi: 42
[C] Algoritmo Di Horner

2 domande..

Allora il programma deve prendere in input grado massimo del polinomio,valore max,minimo e scarto e stampare il ciclo in questo modo:ES

Grado Max: 2
Coeff di x^2:2
Coeff di x^1:3
Coeff di x^0:2

Il polinomio ha questa forma: 2x^2+3x^1+2x^0

Prima domanda: E'Possibile togliere quell' x^0 che è inutile e lasciare +2?

Poi il programma prosegue...ES:
Inserire Valore Iniziale:3
Inserire Valore Finale: 10 x
Scarto: 4 allora stamperà:========> 3(val iniziale)
7(+ 4 perchè è lo scarto)
10(arrivo)

Ora devo stampare la colonna della y i cui valori saranno i risultati che si otterranno sostituendo le x al polinomio
ES:iniziamo con 3: 2x^2+3x^1+2x^0=2*9+3*3+2=29

2° Domanda: Come faccio a sostituire questi valori alla x???


Vi posto il source code

Quote:
/* Tabulazione di un polinomio con l'argoritmo di Horner: Immettere da tastiera
il grado max di un polinomio,immettere ordinatamente i coeff delle potenze
di x, immettere il valore minimo e massimo di x con l'incremento di x.*/

#include <stdio.h>
#include <conio.h>
#define DIM 20
void main(void){

int grado,i,flag;
int inc,max,min;
int n[DIM];


do
{
clrscr();
printf ("\nInserire grado massimo del polinomio: ");
scanf("%d",&grado);


for ( i=0; i<grado+1; i++)
{
printf("\nCoefficiente di x^ %d: ",grado-i);
scanf ("%d", &(n[i]));
}

printf("\n Il polinomio avra la seguente forma: ");


for ( i=0; i<grado+1; i++)
{
printf("+");

printf("%dx^%d",n[i],grado-i);
}


printf("\nInserire Valore Iniziale ==> ");
scanf("%d",&min);

printf("\nInserire Valore Finale ==> ");
scanf("%d",&max);

printf("\nInserire Valore Scarto ==> ");
scanf("%d",&inc);

for (i=min; i<=max; i=i+inc){
printf("\n [%d]",i);

}


} while(flag == 's');
getch();
}



dengel_1 è offline   Rispondi citando il messaggio o parte di esso
Old 26-04-2007, 19:59   #2
wingman87
Senior Member
 
Iscritto dal: Nov 2005
Messaggi: 2774
Quote:
Originariamente inviato da dengel_1 Guarda i messaggi
Prima domanda: E'Possibile togliere quell' x^0 che è inutile e lasciare +2?
basta che controlli se grado-i==0 e in quel caso scrivi solo n[i]
Quote:
Originariamente inviato da dengel_1 Guarda i messaggi

2° Domanda: Come faccio a sostituire questi valori alla x???
ad esempio:
Codice:
float f=0;
int j;

for (i=min; i<=max; i=i+inc){
   for(j=0;j<=grado;j++)
      f=f+n[j]*pow(i,grado-j);
   //stampi il ris
   
   f=0;
}
Ps: non ho guardato cosa sia l'algoritmo di Horner, quindi non so se sta soluzione può andar bene
wingman87 è offline   Rispondi citando il messaggio o parte di esso
Old 27-04-2007, 12:55   #3
dengel_1
Member
 
Iscritto dal: Feb 2007
Messaggi: 42
Ho applicato quello che mi hai detto

Quote:
for (i=min; i<=max; i=i+inc){
for(j=0;j<=grado;j++){
f=f+n[j]*pow(i,grado-j);
printf("\n [%f]",f); }
f=0; }
Ma mi stampa il ciclo della x normalmente e poi delle y in questo modo ES

Polinomio: 2x^2+1x^1+1 ES con 1: 2*1^2+1*1^1+1=4 con 6: 2*6^2+1*6^1+1=79

Dovrebbe stampare solo 4 e 79 ma invece 6 valori di cui 2 corretti..ci siamo quasi
1 =====> 2.0
6 =====> 3.0

e altri valori 4.0 72.00 78.00 79.00(ovviamente in verticale)

Ultima modifica di dengel_1 : 27-04-2007 alle 12:58.
dengel_1 è offline   Rispondi citando il messaggio o parte di esso
Old 27-04-2007, 15:23   #4
shinya
Senior Member
 
L'Avatar di shinya
 
Iscritto dal: Jul 2005
Città: Bologna
Messaggi: 1130
Posto che non penso di aver capito bene il tuo problema, il codice mostrato non mi sembra vada bene se l'esercizio consiste nell'applicare lo schema di horner.

Lo schema di horner si può riassumere all'incirca così: dato un polinomio tipo

a1*x^3 + a2*x^2 + a3*x + a4 (questo è di grado 3 per fare un esempio)

invece di valutarlo nel modo in cui lo scrivi, cioè elevando a potenza, sommando e moltiplicando, lo valuti cosi:

((((a1*x+a2)*x+a3)*x+a4

il programma che ne risulta per valure il polinomio per una certa x è (pseudo-all'incirca):
Codice:
result = a1;
for i = a2 to aN
    result = result * x + ai
end
print result
Si usa spesso per convertire un numero da una base x a base 10, perchè si valutano solo n moltiplicazioni e n addizioni.
shinya è offline   Rispondi citando il messaggio o parte di esso
Old 27-04-2007, 23:48   #5
wingman87
Senior Member
 
Iscritto dal: Nov 2005
Messaggi: 2774
Quote:
Originariamente inviato da dengel_1 Guarda i messaggi
Ho applicato quello che mi hai detto



Ma mi stampa il ciclo della x normalmente e poi delle y in questo modo ES

Polinomio: 2x^2+1x^1+1 ES con 1: 2*1^2+1*1^1+1=4 con 6: 2*6^2+1*6^1+1=79

Dovrebbe stampare solo 4 e 79 ma invece 6 valori di cui 2 corretti..ci siamo quasi
1 =====> 2.0
6 =====> 3.0

e altri valori 4.0 72.00 78.00 79.00(ovviamente in verticale)
Perchè hai riscritto male il mio codice (quando posti del codice usa il tag CODE invece del QUOTE). Se noti nel mio codice non ho messo le graffe nel for più interno.
Comunque come ti avevo detto non ho neanche guardato in cosa consiste l'algoritmo di horner, ho semplicemente calcolato come si farebbe normalmente. Ora rifallo come ti ha detto shinya.
wingman87 è offline   Rispondi citando il messaggio o parte di esso
Old 28-04-2007, 12:09   #6
dengel_1
Member
 
Iscritto dal: Feb 2007
Messaggi: 42
No il tuo codice è giusto..c'erano delle parentesi in +
dengel_1 è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Prova GeForce NOW upgrade Blackwell: il cloud gaming cambia per sempre Prova GeForce NOW upgrade Blackwell: il cloud ga...
Ecovacs Deebot X11 Omnicyclone: niente più sacchetto per lo sporco Ecovacs Deebot X11 Omnicyclone: niente più...
Narwal Flow: con il mocio orizzontale lava i pavimenti al meglio Narwal Flow: con il mocio orizzontale lava i pav...
Panasonic 55Z95BEG cala gli assi: pannello Tandem e audio senza compromessi Panasonic 55Z95BEG cala gli assi: pannello Tande...
HONOR Magic V5: il pieghevole ultra sottile e completo! La recensione HONOR Magic V5: il pieghevole ultra sottile e co...
Cos’è RSL, il nuovo standard che ...
Nissan Micra EV: da 29.500 a oltre 36.00...
Processo Microsoft-ValueLicensing: cosa ...
L'edizione limitata più ambita da...
Lo sviluppatore di MSI Afterburner svela...
Quando l'AI diventa maestro: così...
Sony WH-1000XM6 già scontate su A...
NVIDIA chiede più velocità...
Windows 11 in soli 2,8 GB: con questo sc...
Panico in casa HYTE: ritirato dal mercat...
OPPO Reno14, debutto tra rooftoop esclus...
3DAIQ, il progetto di Concept Reply e TE...
Il parlamento francese contro TikTok: '&...
Apple Watch SE 2ª gen. Cellular a soli 2...
MotoE sospesa dopo il 2025: fine tempora...
Chromium
GPU-Z
OCCT
LibreOffice Portable
Opera One Portable
Opera One 106
CCleaner Portable
CCleaner Standard
Cpu-Z
Driver NVIDIA GeForce 546.65 WHQL
SmartFTP
Trillian
Google Chrome Portable
Google Chrome 120
VirtualBox
Tutti gli articoli Tutte le news Tutti i download

Strumenti

Regole
Non Puoi aprire nuove discussioni
Non Puoi rispondere ai messaggi
Non Puoi allegare file
Non Puoi modificare i tuoi messaggi

Il codice vB è On
Le Faccine sono On
Il codice [IMG] è On
Il codice HTML è Off
Vai al Forum


Tutti gli orari sono GMT +1. Ora sono le: 17:49.


Powered by vBulletin® Version 3.6.4
Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
Served by www3v