Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Lenovo Legion Go 2: Ryzen Z2 Extreme e OLED 8,8'' per spingere gli handheld gaming PC al massimo
Lenovo Legion Go 2: Ryzen Z2 Extreme e OLED 8,8'' per spingere gli handheld gaming PC al massimo
Lenovo Legion Go 2 è la nuova handheld PC gaming con processore AMD Ryzen Z2 Extreme (8 core Zen 5/5c, GPU RDNA 3.5 16 CU) e schermo OLED 8,8" 1920x1200 144Hz. È dotata anche di controller rimovibili TrueStrike con joystick Hall effect e una batteria da 74Wh. Rispetto al dispositivo che l'ha preceduta, migliora ergonomia e prestazioni a basse risoluzioni, ma pesa 920g e costa 1.299€ nella configurazione con 32GB RAM/1TB SSD e Z2 Extreme
AWS re:Invent 2025: inizia l'era dell'AI-as-a-Service con al centro gli agenti
AWS re:Invent 2025: inizia l'era dell'AI-as-a-Service con al centro gli agenti
A re:Invent 2025, AWS mostra un’evoluzione profonda della propria strategia: l’IA diventa una piattaforma di servizi sempre più pronta all’uso, con agenti e modelli preconfigurati che accelerano lo sviluppo, mentre il cloud resta la base imprescindibile per governare dati, complessità e lock-in in uno scenario sempre più orientato all’hybrid cloud
Cos'è la bolla dell'IA e perché se ne parla
Cos'è la bolla dell'IA e perché se ne parla
Si parla molto ultimamente di "bolla dell'intelligenza artificiale", ma non è sempre chiaro perché: l'IA è una tecnologia molto promettente e che ha già cambiato molte cose dentro e fuori le aziende, ma ci sono enormi aspettative che stanno gonfiando a dismisura i valori delle azioni e distorcendo il mercato. Il che, com'è facile intuire, può portare a una ripetizione della "bolla dotcom", e forse anche di quella dei mutui subprime. Vediamo perché
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 12-09-2011, 14:20   #1
blu1988
Member
 
Iscritto dal: May 2010
Messaggi: 42
[C]problema ricorsione

ciao a tutti,
sono abbastanza disperato perchè non riesco a fare questo programma...

allora...come dati iniziali mi vengono forniti due file

file uno:
2
dsp253 1
am2901 2

in questo file il primo numero indica il numero di tipi di processore ,la stringa è il TIPO di processore e intero seguente la stringa è il numero di processori che ho di quel tipo

file due:
7
aaaa 60 am2901
yyyy 40 dsp253
zzzz 10 dsp253
xxxx 20 am2901
kkkk 40 am2901
ffff 70 am2901
hhhh 30 dsp253

in questo file il primo numero indica il numero di operazioni,la stringa(es.aaaa) indica in nome del processo,il numero indica il tempo di esecuzione e la stringa indica il tipo di processore che fa quella det operazione...

mi viene richiesto di trovare l'associazione ottima tra operazioni e processori,in maniera da minimizzare il tempo di esecuzione totale.

ad esempio devo stampare su un file

aaaa am2901 1
yyyy dsp253 1
zzzz dsp253 1
xxxx am2901 1
kkkk am2901 2
ffff am2901 2
hhhh dsp253 1

nome processo,processore che se ne occupa,quale processore se ne occupa.

questa non è la soluzione ottima infatti il tempo di esecuzione maggiore è di am2901 ed è di 110 sec..mi potete aiutare???

vi copio il mio listato per struttura dati e inserimento
Codice:
#include <stdio.h>
#include <stdlib.h>
#include<string.h>
#define TIPO 20+1
#define PRO 30+1
#define MAX 255


typedef struct cpu
{
    char tipo[TIPO];
    int num;
    int *id;
    int tempo;
}cpu_t;

typedef struct process
{
    char nome[PRO];
    int time;
    char tipo[TIPO];
}process_t;

typedef struct ass
{
    char nome_p[PRO];
    char tipo_p[TIPO];
    int id;
}ass_t;

cpu_t* leggifile_uno(cpu_t*v,int*np);//passo anche il puntatore a numero processori
process_t* leggifile_due(process_t*vett,int *no);//e numero operazioni
int count_time(cpu_t*v,process_t*vett,int *no,int *np);
void quicksort (  process_t* vettore, int p, int no );
int partition ( process_t* vettore, int p, int r );
ass_t* cerca_soluzione(cpu_t*v , process_t*vett , int no,int np ,int passo,int max_time );





int main(int argc,char*argv[])
{
    cpu_t*v=NULL;
    process_t *vett=NULL;
    int time_tot,np,no,i;
   ass_t*sequenza;

    v=leggifile_uno(v,&np);
    vett=leggifile_due(vett,&no);
    time_tot=count_time(v,vett,&no,&np);
    printf("\n%d\n",time_tot);
    quicksort(vett, 0, no-1);

    for(i=0;i<no;i++)
    {
        printf("%s %s\n",vett[i].nome,vett[i].tipo);
    }

    sequenza=cerca_soluzione(v,vett,no,np,0,0);
    return 0;
}

cpu_t* leggifile_uno(cpu_t*v,int *np)
{
    FILE *fp;
    char stringa[MAX];
    int i,j;

    printf("Inserisci nome file uno--> \n");
    scanf("%s",stringa);
    fp=fopen(stringa,"r");
    if (fp==NULL)
    {
        printf("ERRORE apertura file 1\n");
        exit(EXIT_FAILURE);
    }

    fscanf(fp,"%d",np);

    v=(cpu_t*)malloc((*np)*sizeof(cpu_t));
    if(v==NULL)
    {
        printf("ERRORE allocazione vettore cpu_t\n");
        exit(EXIT_FAILURE);
    }
    for(i=0;i<(*np);i++)
    {
        fscanf(fp,"%s %d",v[i].tipo,&v[i].num);
        v[i].id=(int*)malloc(v[i].num*sizeof(int));
        if(v[i].id==NULL)
        {
            printf("ERRORE allocazione cpu_t id\n");
            exit(EXIT_FAILURE);
        }
        for(j=0;j<v[i].num;j++)
        {
            v[i].id[j]=0;
        }

    }
    fclose(fp);
    return(v);
}

process_t* leggifile_due(process_t*vett,int *no)
{
    FILE *fp;
    char stringa[MAX];
    int i;

    printf("Inserisci nome file due--> \n");
    scanf("%s",stringa);

    fp=fopen(stringa,"r");
    if(fp==NULL)
    {
        printf("ERRORE apertura file due\n");
        exit(EXIT_FAILURE);
    }

    fscanf(fp,"%d",no);

    vett=(process_t*)malloc((*no)*sizeof(process_t));
    if(vett==NULL)
    {
        printf("ERRORE allocazione vettore process_t\n");
        exit(EXIT_FAILURE);
    }
    for(i=0;i<(*no);i++)
    {
        fscanf(fp,"%s %d %s",vett[i].nome,&vett[i].time,vett[i].tipo);
    }
    fclose(fp);
    return(vett);
    }


int count_time(cpu_t*v,process_t*vett,int *no,int *np)
{
    FILE *fp;
    char stringa[MAX];
    ass_t temp;
    int i,j,t=0;

    printf("Inserire nome file tre--> \n");
    scanf("%s",stringa);

    fp=fopen(stringa,"r");
    if(fp==NULL)
    {
        printf("ERRORE apertura file 3\n");
        exit(EXIT_FAILURE);
    }

    while(fscanf(fp,"%s %s %d",temp.nome_p,temp.tipo_p,&temp.id)!=EOF)
    {
        for(i=0;i<(*no);i++)
        {
            if(strcmp(vett[i].nome,temp.nome_p)==0)
            {
                for(j=0;j<(*np);j++)
                {
                    if(strcmp(v[j].tipo,vett[i].tipo)==0)
                    v[j].id[temp.id-1]+=vett[i].time;
                }
            }
        }
    }

    for(i=0;i<(*np);i++)
    {
        for(j=0;j<(v[i].num);j++)
        {
            if(v[i].id[j]>t)
            t=v[i].id[j];
        }
    }
    fclose(fp);
    return(t);

}

void quicksort ( process_t* vettore, int p, int no )
{
int q;
   if (p < no)
   {
      q = partition(vettore, p, no);
      quicksort(vettore, p, q);
	  quicksort(vettore, q+1, no);
   }
   return;
}

int partition ( process_t*vettore, int p, int r )
{
int i, j;
char *x;
process_t temp;
   x =strdup(vettore[p].tipo); i=p-1; j=r+1;
   while (i < j)
   {
     while(strcmp(vettore[--j].tipo, x)>0);
     while(strcmp(vettore[++i].tipo, x)<0);
	 if (i<j)
      {
        temp = vettore[i];
		vettore[i] = vettore[j];
        vettore[j] = temp;
      }
   }
   return(j);
}
blu1988 è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Lenovo Legion Go 2: Ryzen Z2 Extreme e OLED 8,8'' per spingere gli handheld gaming PC al massimo Lenovo Legion Go 2: Ryzen Z2 Extreme e OLED 8,8'...
AWS re:Invent 2025: inizia l'era dell'AI-as-a-Service con al centro gli agenti AWS re:Invent 2025: inizia l'era dell'AI-as-a-Se...
Cos'è la bolla dell'IA e perché se ne parla Cos'è la bolla dell'IA e perché se...
BOOX Palma 2 Pro in prova: l'e-reader diventa a colori, e davvero tascabile BOOX Palma 2 Pro in prova: l'e-reader diventa a ...
FRITZ!Repeater 1700 estende la rete super-veloce Wi-Fi 7 FRITZ!Repeater 1700 estende la rete super-veloce...
Cloud sovrano: l'approccio di Broadcom c...
HONOR conferma l'arrivo in Italia di Mag...
La Cina sotto pressione impone maniglie ...
OpenAI integra le app in ChatGPT per tra...
NVIDIA sarebbe pronta a tagliare la prod...
Prezzo minimo storico per iPhone 16 Pro:...
Riot Games scopre una falla nei BIOS che...
Beats in super offerta su Amazon: aurico...
Batterie elettriche, Samsung SDI e Stell...
Clivet presenta Fullness, la pompa di ca...
SpaceX lancerà 167 razzi spaziali...
Yakuza Kiwami 3 e Dark Ties protagonisti...
Privacy a rischio: ecco la VPN che regis...
SpaceX ha annunciato che un satellite St...
ASUSTOR presenta i nuovi NAS Lockerstor ...
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: 07:52.


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