Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Recensione Nothing Phone 4(a): sempre iconico ma ora più concreto
Recensione Nothing Phone 4(a): sempre iconico ma ora più concreto
Nothing con il suo nuovo Phone 4(a) conferma la sua identità visiva puntando su una costruzione che nobilita il policarbonato. La trasparenza resta l'elemento cardine, arricchita da una simmetria interna curata nei minimi dettagli. Il sistema Glyph si evolve, riducendosi nelle dimensioni ma aumentando l'utilità quotidiana grazie a nuove funzioni software integrate e notifiche visive. Ecco tutti i dettagli nella recensione completa
Corsair Vanguard Air 99 Wireless: non si era mai vista una tastiera gaming così professionale
Corsair Vanguard Air 99 Wireless: non si era mai vista una tastiera gaming così professionale
Nelle ultime settimane abbiamo provato la Corsair Vanguard Air 99 Wireless, una tastiera tecnicamente da gaming, ma che in realtà offre un ampio ventaglio di possibilità anche al di fuori delle sessioni di gioco. Flessibilità e funzionalità sono le parole d'ordine di una periferica che si rivolge a chi cerca un prodotto capace di adattarsi a ogni esigenza e ogni piattaforma
Ecovacs DEEBOT T90 PRO OMNI: ora il rullo di lavaggio è ampio
Ecovacs DEEBOT T90 PRO OMNI: ora il rullo di lavaggio è ampio
DEEBOT T90 PRO OMNI abbina un sistema di aspirazione basato su tecnologia BLAST ad un rullo di lavaggio dei pavimenti dalla larghezza elevata, capace di trattare al meglio le superfici di casa minimizzando i tempi di lavoro. Un robot completo che riesce anche ad essere sottile e garantire automazione ed efficienza nelle operazioni di pulizia di casa
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 03-12-2011, 13:14   #1
diegolbj6
Member
 
L'Avatar di diegolbj6
 
Iscritto dal: Jan 2011
Città: lecce
Messaggi: 198
Algoritmi

Salve ragazzi mi sto cimentando nella risoluzione di alcuni algoritmi elementari, ma vista la mia incompetenza in materia, non riesco a capirne il funzionamento.
Per iniziare a capire qualcosa volevo provare con la formulazione di un algoritmo che mi dia il fattoriale di un numero n, ed anche con la formulazione dell'algoritmo di un numero x elevato ad n (x^n).
Conoscendo il procedimento matematico, non riesco a trovare il nesso logico con il ciclo di ripetizione finchè, e nemmeno con quello PER, e non avendo le basi necessarie mi blocco ripetutamente ad una non soluzione.
__________________
Hwuprage better than facebook, just enjoy the fun
2k shit you suck
Ho concluso positivamente con spl
diegolbj6 è offline   Rispondi citando il messaggio o parte di esso
Old 03-12-2011, 14:55   #2
gagginaspinnata
Member
 
Iscritto dal: Dec 2005
Messaggi: 37
Quote:
la formulazione dell'algoritmo di un numero x elevato ad n
Questo è molto semplice.

x^2 = x * X
x^3 = x * x * x
ecc.

Per X^n devi fare un ciclo di n-1 volte dove moltiplichi X * X

Ad esempio

Codice:
<?php

function esponente($x , $n){

$ris = 1;

	for($i=1;$i<=$n ; $i++){

		$ris = $ris * $x;

	}

	return $ris;

}

echo esponente(3,3);

?>
Dovrebbe andare
gagginaspinnata è offline   Rispondi citando il messaggio o parte di esso
Old 03-12-2011, 15:07   #3
Gimli[2BV!2B]
Senior Member
 
L'Avatar di Gimli[2BV!2B]
 
Iscritto dal: Feb 2006
Città: Parma
Messaggi: 3010
Invece di darti un esempio proverò a scriverti quello che è il mio usuale approccio ad un problema.
  1. Qual'è la formula o il più generale obiettivo da perseguire?
  2. Qual'è l'esatta sequenza di operazioni che faresti per calcolare/eseguire un caso specifico? (naturalmente limitando i dati in modo da poter scrivere od immaginare l'intera sequenza)
  3. Esiste una porzione della sequenza di operazioni che si ripete più volte con le stesse operazioni e condizioni ma con dati diversi?
  4. Riesci a dare un nome rappresentativo a tutti i dati utilizzati?
  5. Quali operazioni, dati e/o calcoli sono necessari per essere pronti ad iniziare il calcolo?
  6. Quali condizioni permettono di capire che il calcolo è terminato?
  7. Mettiamo che il problema sia il numero x^n, se voglio calcolare 1^1 o 1^0 il tuo algoritmo da il risultato atteso in questi casi?
Generalizzando:
  1. Devi aver chiaro il problema, oppure spezzarlo in problemi più piccoli ben definiti.
  2. Determina una soluzione esatta del problema.
  3. Determina le eventuali porzioni ripetitive e sostituiscile con una ripetizione della sequenza minima.
  4. Parametrizza i dati.
  5. Determina condizioni e stato iniziale.
  6. Determina condizioni e stato finale.
  7. Analizza il comportamento nei casi limite.
Personalmente ho riscontrato che il controllo dei casi limite può portare ad apportare discrete variazioni alla soluzione, quindi il sesto punto è l'ultimo solo perché è possibile controllarlo solo quando si ha un algoritmo abbozzato, ma può costringere a tornare indietro di qualche passo.
Il punto uno è un piccolo mondo a se in caso di grandi problemi, praticamente si dovrebbe cercare di suddividere l'algoritmo richiesto in un insieme di problemi più piccoli, chiari e più semplici da risolvere, che si risolveranno separatamente e verranno poi combinati per dare una soluzione completa.

Uno strumento che permette di rappresentare efficacemente un algoritmo è il diagramma di flusso, ti consiglierei di provare a disegnarli perché credo permettano di assimilare meglio il metodo.
__________________
~Breve riferimento ai comandi GNU/Linux (ormai non molto breve...)
Gimli[2BV!2B] è offline   Rispondi citando il messaggio o parte di esso
Old 03-12-2011, 21:00   #4
IngMetallo
Senior Member
 
L'Avatar di IngMetallo
 
Iscritto dal: Feb 2011
Messaggi: 2013
Quote:
Originariamente inviato da Gimli[2BV!2B] Guarda i messaggi

[CUT]

Uno strumento che permette di rappresentare efficacemente un algoritmo è il diagramma di flusso, ti consiglierei di provare a disegnarli perché credo permettano di assimilare meglio il metodo.
Verissimo !!! Io ho cominciato da poco e all'università al corso di fondamenti il professore ci faceva addirittura eseguire i diagrammi di flusso a mano per verificare che il programma funzionasse.. a volte perdevamo più tempo per controllare il diagramma che non ad elaborare l'algoritmo.. Alla fine però ne è valsa la pena perché fai l'abitudine a padroneggiare cicli e condizioni
__________________
CPU: Intel i5 2500k; GPU: Asus GTX 970 ; Scheda audio: Asus Xonar U7; RAM: 16GB DDR3; Storage: HD 750GB+SSD Samsung 840 (128GB); OS: Arch Linux | Linux Mint 18 | Win 7 (gaming)
Thread ufficiali : Linux Mint 18 | Ubuntu 16.04
| Desktop Environments & Window Manager per Linux
IngMetallo è offline   Rispondi citando il messaggio o parte di esso
Old 04-12-2011, 10:57   #5
diegolbj6
Member
 
L'Avatar di diegolbj6
 
Iscritto dal: Jan 2011
Città: lecce
Messaggi: 198
Visto che lo devo fare a mano, se scrivo in questo modo è coretto?
inizio
leggi n
Se (n=0)
allora
msg: "il fattoriale di 0 è 1";
fine allora
altrimenti
fatt(n)=1
finchè (n>0)
fatt(n)=n*fatt (n-1)
fine finchè
stampa: fatt(n)
fine allora
fine se
fine
__________________
Hwuprage better than facebook, just enjoy the fun
2k shit you suck
Ho concluso positivamente con spl
diegolbj6 è offline   Rispondi citando il messaggio o parte di esso
Old 04-12-2011, 15:29   #6
Gimli[2BV!2B]
Senior Member
 
L'Avatar di Gimli[2BV!2B]
 
Iscritto dal: Feb 2006
Città: Parma
Messaggi: 3010
L'elaborazione del fattoriale è l'esempio principe per la programmazione ricorsiva (in soldoni una funzione che richiama se stessa passandosi le variabili aggiornate e ritornando il risultato parzialmente calcolato).

Il metodo ricorsivo non è però l'unico approccio, è possibile risolvere il problema comodamente anche in modo iterativo (cioè con un semplice ciclo).

La tua soluzione, così com'è scritta, è una via di mezzo tra soluzione ricorsiva ed iterativa.
Non avendo definito una funzione, fatt(n) sembra un improprio nome di variabile (l'hai anche inizializzato).
È presente il test per il termine dell'elaborazione ricorsiva (serve per la soluzione iterativa?).

Mettiamo un paio di paletti:
  1. diciamo che vogliamo risolvere in modo iterativo
  2. diamo un nome migliore alla variabile che contiene il risultato: fatt(n) -> fatt_n
Codice indentato e con il nuovo nome di variabile (ho cercato anche di capire come combinare le parole Altrimenti, ecc... non so bene quale sia la convenzione che adotti ma mi sembrava mancasse qualcosa...):
Codice:
Inizio
  leggi n ;
  Se (n = 0)
    Allora
      msg: "il fattoriale di 0 è 1" ;
    fine Allora
    Altrimenti
      fatt_n = 1 ;

      Finchè (n > 0)
        fatt_n = n * fatt_n ;
        ***devi fare qualcos'altro***
      fine Finchè
      Stampa: fatt_n ;
    fine Altrimenti
  fine Se
fine
La soluzione iterativa può esser ridotta ulteriormente.
Se hai già affrontato l'argomento funzioni potresti modificare il codice in modo da renderlo correttamente ricorsivo (anche in questo caso la tua proposta di soluzione non era molto distante dall'essere corretta).
__________________
~Breve riferimento ai comandi GNU/Linux (ormai non molto breve...)
Gimli[2BV!2B] è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Recensione Nothing Phone 4(a): sempre iconico ma ora più concreto Recensione Nothing Phone 4(a): sempre iconico ma...
Corsair Vanguard Air 99 Wireless: non si era mai vista una tastiera gaming così professionale Corsair Vanguard Air 99 Wireless: non si era mai...
Ecovacs DEEBOT T90 PRO OMNI: ora il rullo di lavaggio è ampio Ecovacs DEEBOT T90 PRO OMNI: ora il rullo di lav...
Recensione Samsung Galaxy S26 Ultra: finalmente qualcosa di nuovo Recensione Samsung Galaxy S26 Ultra: finalmente ...
Diablo II Resurrected: il nuovo DLC Reign of the Warlock Diablo II Resurrected: il nuovo DLC Reign of the...
NVIDIA DLSS 5 a sorpresa: molti sviluppa...
I nuovi Xiaomi 17T e 17T Pro sono vicini...
Scandalo in aula a Londra: testimone usa...
Starlink cambia le tariffe anche per i v...
Monitor in offerta su Amazon: dal gaming...
Core i7-13645HX spunta dal nulla: un nuo...
NVIDIA mette Rubin CPX in un angolo: pun...
Oral-B iO in sconto su Amazon: spazzolin...
OnePlus non si ferma: è in arrivo...
7 robot aspirapolvere bestseller al prez...
Apple completa una nuova acquisizione: &...
Logitech taglia i prezzi delle periferic...
JD.com punta sull'Europa e sfida Amazon ...
Blink e Ring in forte sconto su Amazon: ...
Microsoft potrebbe fare causa ad OpenAI ...
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: 10:38.


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