Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Plaud NotePin S, il registratore IA si fa indossabile (ma è facile da perdere)
Plaud NotePin S, il registratore IA si fa indossabile (ma è facile da perdere)
Quattro modi di indossarlo, stessa app del Plaud Note Pro e integrazione con il desktop. Il registratore IA da indossare di Plaud eccelle in mobilità, ma resta vincolato all'abbonamento ed è facile da perdere
Redmi Watch 6 in prova: lo smartwatch con ampio display da 2000 nit a meno di 100 euro
Redmi Watch 6 in prova: lo smartwatch con ampio display da 2000 nit a meno di 100 euro
Xiaomi ha portato Redmi Watch 6 anche sul mercato italiano, puntando su un display AMOLED da 2,07 pollici con picco di luminosità a 2000 nit, frame in alluminio da 9,9mm e un'autonomia dichiarata di 12 giorni. Lo smartwatch gira su HyperOS 3 e integra GPS, Bluetooth 5.4 e oltre 150 sport mode. Il tutto a meno di 100 euro
Mad Catz M.M.O. 7+: lo stesso DNA del R.A.T. 8+ ADV, ma con molti più pulsanti
Mad Catz M.M.O. 7+: lo stesso DNA del R.A.T. 8+ ADV, ma con molti più pulsanti
Con 22 tasti, il pulsante 5D, lo Shift Mode e il sensore PixArt 3395 da 26.000 DPI, il nuovo mouse wireless di Mad Catz si rivolge in modo preciso ai giocatori di MMO e RPG. Ma chi conosce già il R.A.T. 8+ ADV si accorgerà subito di quanto i due prodotti condividano, e di dove invece divergono
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 21-06-2015, 19: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, 00: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, 13: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, 17: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 17:59.
mrcolly è offline   Rispondi citando il messaggio o parte di esso
Old 22-06-2015, 19: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, 19: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


Plaud NotePin S, il registratore IA si fa indossabile (ma è facile da perdere) Plaud NotePin S, il registratore IA si fa indoss...
Redmi Watch 6 in prova: lo smartwatch con ampio display da 2000 nit a meno di 100 euro Redmi Watch 6 in prova: lo smartwatch con ampio ...
Mad Catz M.M.O. 7+: lo stesso DNA del R.A.T. 8+ ADV, ma con molti più pulsanti Mad Catz M.M.O. 7+: lo stesso DNA del R.A.T. 8+ ...
Radeon RX 9070 GRE, AMD la porta in tutto il mondo | Recensione Gigabyte Gaming OC Radeon RX 9070 GRE, AMD la porta in tutto il mon...
Reolink OMVI 3i WiFi: videosorveglianza più intelligente e facile da usare Reolink OMVI 3i WiFi: videosorveglianza pi&ugrav...
Virtua Fighter è tornato e non &e...
Il ritorno di Fumito Ueda, autore di Sha...
Cooler Master svela GPU Shield, la nuova...
Samsung Galaxy S27 Pro: sarà lui ...
Così Google ha ottimizzato Chrome...
Xiaomi non cambia idea: il display poste...
LG presenta in Italia le gamme TV Micro ...
Sette anni dopo l'annuncio, The Wolf Amo...
'Non avrete aumenti': la decisione shock...
TIM lancia il Pass Mondiali DAZN: 104 pa...
Tesla Roadster, promessa o miraggio? La ...
Mark Hamilton, la tavola periodica del m...
Hanger 13 annuncia Uomo d'Onore: espansi...
La battaglia delle HBM4 entra nel vivo: ...
Dopo 12 anni torna Alien: Isolation. Ecc...
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: 22:07.


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