Torna indietro   Hardware Upgrade Forum > Software > Programmazione

AWS annuncia European Sovereign Cloud, il cloud sovrano per convincere l'Europa
AWS annuncia European Sovereign Cloud, il cloud sovrano per convincere l'Europa
AWS è il principale operatore di servizi cloud al mondo e da tempo parla delle misure che mette in atto per garantire una maggiore sovranità alle organizzazioni europee. L'azienda ha ora lanciato AWS European Sovereign Cloud, una soluzione specificamente progettata per essere separata e distinta dal cloud "normale" e offrire maggiori tutele e garanzie di sovranità
Redmi Note 15 Pro+ 5G: autonomia monstre e display luminoso, ma il prezzo è alto
Redmi Note 15 Pro+ 5G: autonomia monstre e display luminoso, ma il prezzo è alto
Xiaomi ha portato sul mercato internazionale la nuova serie Redmi Note, che rappresenta spesso una delle migliori scelte per chi non vuole spendere molto. Il modello 15 Pro+ punta tutto su una batteria capiente e su un ampio display luminoso, sacrificando qualcosa in termini di potenza bruta e velocità di ricarica
HONOR Magic 8 Pro: ecco il primo TOP del 2026! La recensione
HONOR Magic 8 Pro: ecco il primo TOP del 2026! La recensione
HONOR ha finalmente lanciato il suo nuovo flagship: Magic 8 Pro. Lo abbiamo provato a fondo in queste settimane e ve lo raccontiamo nella nostra recensione completa. HONOR rimane fedele alle linee della versione precedente, aggiungendo però un nuovo tasto dedicato all'AI. Ma è al suo interno che c'è la vera rivoluzione grazie al nuovo Snapdragon 8 Elite Gen 5 e alla nuova MagicOS 10
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


AWS annuncia European Sovereign Cloud, il cloud sovrano per convincere l'Europa AWS annuncia European Sovereign Cloud, il cloud ...
Redmi Note 15 Pro+ 5G: autonomia monstre e display luminoso, ma il prezzo è alto Redmi Note 15 Pro+ 5G: autonomia monstre e displ...
HONOR Magic 8 Pro: ecco il primo TOP del 2026! La recensione HONOR Magic 8 Pro: ecco il primo TOP del 2026! L...
Insta360 Link 2 Pro e 2C Pro: le webcam 4K che ti seguono, anche con gimbal integrata Insta360 Link 2 Pro e 2C Pro: le webcam 4K che t...
Motorola edge 70: lo smartphone ultrasottile che non rinuncia a batteria e concretezza Motorola edge 70: lo smartphone ultrasottile che...
KIOXIA: 'il tempo degli SSD a basso cost...
Apple perde la sua posizione privilegiat...
CovertLabs lancia l'allarme: 198 app AI ...
Smart TV QLED da 75 pollici a 559€ su Am...
Nello Spazio l'evoluzione cambia rotta: ...
Il fondatore di Waymo critica l'FSD di T...
Rincari GPU: NVIDIA alza il costo della ...
Robot tagliaerba a 699€ su Amazon: un Se...
Nova Launcher cambia proprietà: perché t...
Stop a TikTok e Instagram dopo le 21: pa...
A Seul in arrivo nuovi incentivi per aut...
7 offerte nuove di zecca Amazon, altre a...
Una giornata di lavoro con l'IA consuma ...
'Non fate usare ChatGPT ai vostri cari':...
Un display che si allunga fino al 200% s...
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:11.


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