Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Snowflake porta l'IA dove sono i dati, anche grazie a un accordo con OpenAI
Snowflake porta l'IA dove sono i dati, anche grazie a un accordo con OpenAI
Snowflake ha presentato diverse novità per la sua piattaforma legate all'intelligenza artificiale. Quella forse più eclatante è una collaborazione con OpenAI, ma non mancano diverse nuove funzionalità che rendono la piattaforma più flessibile e in grado di rispondere meglio alle esigenze in continuo cambiamento delle aziende
Sistema Mesh Roamii BE Pro: il Wi-Fi 7 secondo MSI
Sistema Mesh Roamii BE Pro: il Wi-Fi 7 secondo MSI
Con velocità teoriche fino a 11 Gbps, gestione tramite app intelligente e protezione avanzata dei dispositivi, Roamii BE Pro porta il Wi‑Fi 7 tri‑band nelle abitazioni più esigenti. Un sistema Wi-Fi Mesh proposto da MSI allo scopo di garantire agli utenti una rete fluida e continua capace di sostenere streaming 8K, gaming competitivo e le applicazioni moderne più esigenti in termini di banda
Recensione HUAWEI Mate X7: un foldable ottimo, ma restano i soliti problemi
Recensione HUAWEI Mate X7: un foldable ottimo, ma restano i soliti problemi
Mate X7 rinnova la sfida nel segmento dei pieghevoli premium puntando su un design ancora più sottile e resistente, unito al ritorno dei processori proprietari della serie Kirin. L'assenza dei servizi Google e del 5G pesa ancora sull'esperienza utente, ma il comparto fotografico e la qualità costruttiva cercano di compensare queste mancanze strutturali con soluzioni ingegneristiche di altissimo livello
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 21-06-2015, 20:46   #1
jokerthep
Junior Member
 
Iscritto dal: Sep 2014
Messaggi: 7
Mi serve una mano

Il Bancomat
Lo sportello bancomat di una certa banca ha a disposizione banconote di taglio pari a 5 €, 10 €, 20 €, 50
€, 100 €e 500 €in quantita illimitate. Un certo numero n di clienti e in fila la per prelevare e supponiamo
che l'i-esimo cliente voglia prelevare qi euro. Per semplicita puoi assumere che qi sia multiplo di 5 €. Ad
esempio, non e ammesso prelevare 103 €oppure 272 €. Il bancomat deve soddisfare le richieste di ciascun
cliente usando il minor numero possibile di banconote.
Risolvi i seguenti esercizi:
1. Supponiamo che un cliente voglia prelevare 20 euro. In quanti modi e possibile soddisfare le sue
richieste? Cosa succede nel caso in cui il cliente voglia prelevare 50 euro?
2. Scrivi una funzione C che riceve in ingresso un intero b (budget) e calcola il minimo numero di
banconote necessarie per raggiungere il budget b. Ad esempio seb = 600 occorrono almeno tre
banconote (una da 500 €e due da 100 €e non e possibile usare un minor numero di banconote).
Se invece b = 150 allora due banconote (una da 100 €e una da 50 €) sono sufficienti. Qual'e la
complessita della funzione proposta? Dipende dal valore di b? Supponi che b sia del tipo b = 5^k, con
k intero appropriato. Possiamo stimare la complessita della funzione in questo caso?
3. Supponiamo che le richieste dei clienti siano codificate in un opportuno vettore b tale che b[i] rappresenti
il budget che l'utente i-esimo. Scrivi una funzione che stampa, per ciascun cliente, il minimo
numero di banconote necessario per soddisfare le esigenze di ciascun cliente. Qual'e la complessita
dell'algoritmo proposto? Modifica la funzione in modo che restituisca il numero complessivo di
banconote erogate. Qual'e la complessita dell'algoritmo proposto?

Codice:
#include <stdio.h>
#include <stdlib.h>
void min_banc (int);
int badg, j,b[9];	
	
	
main()
{
for(int j=0 ; j<=9 ; j++)
{	
	printf("inserisci quantita' banconote da prelevare\n ");
 	scanf ("%d",&b[j]);

	while((b[j]%5)!=0)
	{
		if((b[j]%5)!=0)
		printf("iserire valori multipli di 5\n");
		printf("inserisci quantita' banconote da prelevare\n");
		scanf ("%d",&b[j]);	
	}
  min_banc (b[j]);
}
}

void min_banc (int)
{
	int banc[] = {5,10,20,50,100,500};
	int i = 5;
	int euro=0;
	
	while(b[j]>0)
	{		
		if(banc[i]<= b[j])
		{
			b[j]=b[j]-banc[i];
			euro++;
		}
		else 
			i--;		
	}
	printf ("sono state usate %d banconote\n",euro);
}
Non riesco a capire dove sbaglio, quando lo eseguo per la seconda volta torna a 0 e rimane sempre a 0 ....
jokerthep è offline   Rispondi citando il messaggio o parte di esso
Old 22-06-2015, 01:17   #2
mrcolly
Junior Member
 
Iscritto dal: Jun 2015
Messaggi: 4
l'errore è in
Codice:
for(int j=0 ; j<=9 ; j++)
aggiungendo "int" è come se instanziassi un'altra variabile j all'interno del ciclo for ma nella funzione min_banc() la j si riferisce alla variabile globale che rimane sempre a zero.


cosi dovrebbe funzionare
Codice:
for( j=0 ; j<=9 ; j++)
oppure, al posto di lavorare con le variabili globali, che non è mai un bene, potresti passare l'argomento alla funzione

Codice:
void min_banc (int input)
{
	int banc[] = {5,10,20,50,100,500};
	int i = 5;
	int euro=0;
	
	while(input>0)
	{		
		if(banc[i]<= input)
		{
			input=input-banc[i];
			euro++;
		}
		else 
			i--;		
	}
	printf ("sono state usate %d banconote\n",euro);
}
mrcolly è offline   Rispondi citando il messaggio o parte di esso
Old 22-06-2015, 14:06   #3
jokerthep
Junior Member
 
Iscritto dal: Sep 2014
Messaggi: 7
Grazie mille! era una cavolata che avevo sotto gli occhi

ho un altro problema con questo codice:

Codice:
#include <stdio.h>
#include <stdlib.h>

int main()

{
    int A[] = {0, 2, 4, 6,};
    int m = 4;
    int B[] = {9, 8, 7, 6, 3, 1};
    int n = 6;
    int C[10];
    int i, j, k;
    i = 0;
    j = n-1;
    k = 0;
    while (i<m && j>=0)
    {
         if (A[i]<B[j])
         {
               C[k]=A[i];
               i++;
               k++;
         }
         else
         {
               C[k]=B[j];
               j--;
               k++;
         }      
    }
    while (i<m)
    {
         C[k]=A[i];
         i++;
         k++;
    }
    while (j>=0)
    {
         C[k]=B[j];
         j--;
         k++;
    }
    printf (" ARRAY C :\n");
    for (k =0; k< 10; k ++)
    printf ("C[%d] = %d\n",k,C[k]);
    system("pause");
}
Non riesco ad eliminare i doppioni
jokerthep è offline   Rispondi citando il messaggio o parte di esso
Old 22-06-2015, 18:56   #4
mrcolly
Junior Member
 
Iscritto dal: Jun 2015
Messaggi: 4
non so se ti devi limitare a quelle variabili, ma io userei un altro array di supporto

Codice:
#include <stdio.h>
#include <stdlib.h>

int main()

{
    int A[] = {0, 2, 4, 6,};
    int m = 4;
    int B[] = {9, 8, 7, 6, 3, 1};
    int n = 6;
    int C[10];
    int D[10];
    int i, j, k;
    i = 0;
    j = n-1;
    k = 0;
    while (i<m && j>=0)
    {
         if (A[i]<B[j])
         {
               C[k]=A[i];
               i++;
               k++;
         }
         else
         {
               C[k]=B[j];
               j--;
               k++;
         }      
    }
    while (i<m)
    {
         C[k]=A[i];
         i++;
         k++;
    }
    while (j>=0)
    {
         C[k]=B[j];
         j--;
         k++;
    }
    
    for(int x=0;x<k;x++){
        if(C[x]!=C[x+1]){
            D[j]=C[x];
            j++;
        }
    }
    
    printf (" ARRAY D :\n");
    for (k =0; k< j; k ++)
    printf ("D[%d] = %d\n",k,D[k]);
    system("pause");
}

Ultima modifica di mrcolly : 22-06-2015 alle 18:59.
mrcolly è offline   Rispondi citando il messaggio o parte di esso
Old 22-06-2015, 20:20   #5
jokerthep
Junior Member
 
Iscritto dal: Sep 2014
Messaggi: 7
eh ma non stampa
nè lo 0 nè il 9
jokerthep è offline   Rispondi citando il messaggio o parte di esso
Old 22-06-2015, 20:30   #6
mrcolly
Junior Member
 
Iscritto dal: Jun 2015
Messaggi: 4
ah si, ho fatto male i conti perchè j era a -1

Codice:
    j=0;
    for(int x=0;x<k;x++){
        if(C[x]!=C[x+1]){
            D[j]=C[x];
            j++;
        }
    }
mrcolly è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Snowflake porta l'IA dove sono i dati, anche grazie a un accordo con OpenAI Snowflake porta l'IA dove sono i dati, anche gra...
Sistema Mesh Roamii BE Pro: il Wi-Fi 7 secondo MSI Sistema Mesh Roamii BE Pro: il Wi-Fi 7 secondo M...
Recensione HUAWEI Mate X7: un foldable ottimo, ma restano i soliti problemi Recensione HUAWEI Mate X7: un foldable ottimo, m...
Nioh 3: souls-like punitivo e Action RPG Nioh 3: souls-like punitivo e Action RPG
Test in super anteprima di Navimow i220 LiDAR: il robot tagliaerba per tutti Test in super anteprima di Navimow i220 LiDAR: i...
Pokémon Pokopia: la durata della ...
UBS taglia centinaia di posti in Svizzer...
Samsung invia i primi sample di memoria ...
Xbox Game Pass per PC potrebbe aumentare...
Primo test con Dacia Spring 2026: motore...
Italia sempre più digitale, anche...
Tutte le offerte Amazon di oggi: 13 novi...
CD Projekt RED punta sull'Intelligenza A...
Offerte Oral-B iO su Amazon: spazzolini ...
Consegne sempre più rapide: Amazo...
Epic introduce l'anticheat di livello ke...
Google Gemini sfruttato da hacker di Sta...
Braun taglia i prezzi su Amazon: dai ras...
Helldivers al cinema: Jason Momoa nel ca...
Gli occhiali AI fanno volare EssilorLuxo...
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: 14:41.


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