Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Recensione realme 12+: sfida la fascia media con un design unico e un display luminosissimo
Recensione realme 12+: sfida la fascia media con un design unico e un display luminosissimo
Il nuovo dispositivo top della Serie 12 arriva dopo le varianti "Pro" e si configura come una proposta di gamma media ben equilibrata, capace di rivolgersi a un pubblico molto ampio formato sia di utenti esigenti, sia di persone attente al risparmio. Non adotta il SoC più potente del mercato, ma punta di catturare le attenzioni attraverso un display AMOLED da 120Hz e 2000 nit, una fotocamera principale di qualità e, soprattutto, un design particolare.
OnePlus Pad Go: un tablet economico perfetto per l'intrattenimento. La recensione
OnePlus Pad Go: un tablet economico perfetto per l'intrattenimento. La recensione
OnePlus Pad Go è un tablet Android di fascia media che offre un'esperienza di intrattenimento immersiva grazie al display 2.4K, all'audio Dolby Atmos, alla connettività LTE e a un design premium, il tutto a un prezzo molto competitivo. Ecco tutti i dettagli nella nostra recensione completa.
Per Huawei l’IA è una questione di storage. Presentate soluzioni dedicate e un SSD da 128 TB
Per Huawei l’IA è una questione di storage. Presentate soluzioni dedicate e un SSD da 128 TB
Inizia l’era dell’AI storage. Durante l’Innovative Data Infrastructure Forum 2024, Huawei ha presentato OceanStor A800, una soluzione innovativa pensata per i carichi di lavoro legati all’intelligenza artificiale generativa
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 19-11-2003, 18:58   #101
Sephiroth83
Member
 
L'Avatar di Sephiroth83
 
Iscritto dal: May 2003
Città: Torino
Messaggi: 63
Se mi date tempo fino a sabato (venerdì pomeriggio ho un esame di Teoria dei segnali quindi fino ad allora non molto tempo libero...) vedo di implementare l'algoritmo che mi è venuto in mente (anche grazie ai suggerimenti di a2000).

Intanto se modifico quello vecchio col quale ho generato la matrice 100x100 (in pratica tolgo la ricorsione per non avere limiti allo stack) penso di poter arrivare a 10000x10000 in pochi secondi.
Il problema di questo programma è che accetta solo matrici con lati di lunghezza multipla di 5...

Col programma brute force ho scoperto anche che per una matrice 5x5, partendo da qualunque punto si può arrivare in qualunque altro punto della matrice (ovviamente eccetto il punto di partenza). Ad esempio posso volere una matrice che cominci da (3,4) e finisca in (4,4) e so che esiste (so anche come è fatta). Non è niente di complicato, però è interessante!
__________________
AMD K6 450 MHz, Epox MVP3G2 FSB 100 MHz, 320 MB RAM, HDD IBM 7200 60 GB, VooDoo III (è vecchia ma per diablo II va ancora bene )
Sephiroth83 è offline   Rispondi citando il messaggio o parte di esso
Old 20-11-2003, 08:26   #102
/\/\@®¢Ø
Bannato
 
L'Avatar di /\/\@®¢Ø
 
Iscritto dal: Jul 2000
Città: Malo (VI)
Messaggi: 994
Quote:
Originariamente inviato da a2000
no quella è in queste 15.

Codice:
Function f_arcobaleno(a$) As String
 
 Dim c$(1 To 5)
 c$(1) = "red"
 c$(2) = "orange"
 c$(3) = "yellow"
 c$(4) = "green"
 c$(5) = "blue"
 
 b$ = ""
 ic% = 2
 For i% = 1 To Len(a$)
  a1$ = Mid$(a$, i%, 1)
   ic% = 1 + i% Mod 5
   b$ = b$ + "[ccolor=" + c$(ic%) + "]" + Mid$(a$, i%, 1) + "[/ccolor]"
 Next i%
 
 f_arcobaleno = b$


End Function
Purtroppo per ora non ho tempo da dedicare al gioco, pero' posso offrirti la mia variante della funzione arcobaleno
Versione python

Codice:
 color = ['red','orange','yellow','green','blue']
n = len(color)

def arcobaleno( str ):
    result = ''
    for i in range(0,len(str) ):
        result += "[ccolor=" + color[i%n] + "]" + str[i] + "[/ccolor]"
    return result
(in python sono alle prime armi, quindi prendetela con le pinze )

edit: avevo dimenticato la versione Haskell (3 righe )
(non testata ma dovrebbe andare)
Codice:
color = ["red","orange","yellow","green","blue"]
decor (col,char) = "[ccolor=" ++ col ++ "]" ++ [char] ++ "[/ccolor]"
arcobaleno str = map decor $ zip (cycle color) str

Per le cose serie dovrai aspettare un po' di piu' temo

Ultima modifica di /\/\@®¢Ø : 20-11-2003 alle 18:42.
/\/\@®¢Ø è offline   Rispondi citando il messaggio o parte di esso
Old 20-11-2003, 08:54   #103
a2000
Bannato
 
L'Avatar di a2000
 
Iscritto dal: Jan 2001
Messaggi: 1976
è dura la vita dei commessi viaggiatori, eh /\/\@®¢Ø ....
a2000 è offline   Rispondi citando il messaggio o parte di esso
Old 20-11-2003, 09:03   #104
a2000
Bannato
 
L'Avatar di a2000
 
Iscritto dal: Jan 2001
Messaggi: 1976
per esempio:


" Un problema che da lungo tempo ha attratto i matematici è il problema del commesso viaggiatore.

Un commesso viaggiatore deve visitare un certo numero di città; conosce la lunghezza ( o il tempo o il costo, a seconda dei casi) dello spostamento necessario per recarsi da una città all’altra: vuole determinare il percorso più breve ( o più veloce o più economico) che gli permetta di partire da casa sua e di farvi ritorno dopo aver visitato ogni città una sola volta. Come può fare? "




http://digilander.libero.it/dimauro/...ames/commesso/
a2000 è offline   Rispondi citando il messaggio o parte di esso
Old 20-11-2003, 10:33   #105
Strat
Member
 
L'Avatar di Strat
 
Iscritto dal: Oct 2003
Messaggi: 109
Il problema del commesso viaggiatore.

Tradotto nel linguaggio della teoria dei grafi, il problema consiste nel trovare un ciclo di Hamilton di peso minimo in un grafo pesato completo, cioè si vuole trovare un ciclo ottimale.

Non esiste nessun algoritmo efficace per risolvere tale problema!

Si può comunque trovare una soluzione raginevole.

Esiste un metodo trovato da Lin, Held e Karp ma non è straordinario.

Volevo solo precisare che è tosto.

Più semplice è il problema del postino cinese. ( Algoritmo di Fleury).

Ciao!
Strat è offline   Rispondi citando il messaggio o parte di esso
Old 20-11-2003, 10:42   #106
lombardp
Senior Member
 
L'Avatar di lombardp
 
Iscritto dal: Jun 2002
Città: Firenze
Messaggi: 630
Parole, parole, parole... ma finora non ho visto nessun codice completo!

Fateli vedere questi algoritmi !!!
__________________
---> Lombardp
CSS Certified Expert (Master Level) at Experts-Exchange
Proud user of LITHIUM forum : CPU technology
Webmaster of SEVEN-SEGMENTS : Elettronica per modellismo
lombardp è offline   Rispondi citando il messaggio o parte di esso
Old 20-11-2003, 10:49   #107
a2000
Bannato
 
L'Avatar di a2000
 
Iscritto dal: Jan 2001
Messaggi: 1976
ah sì, lo conosco:


Un postino cinese deve spedire 100 lettere a tutti i suoi amici postini in diverse città della Cina.
decide di comprare cento francobolli di costo diverso per ognuna delle destinazioni.
Va dal tabaccaio il quale, per dargli i francobolli più appropriati, gli pone le seguenti domande:

1) in che tipo di zona deve andare ogni singola lettera (rurale, marina, montuosa ecc.)

2) l'età del destinatario

3) il suo stato civile

4) gli hobby del destinatario

5) il colore della busta

6) ....

mentre sta per porgli la sesta domanda entra un'altro cliente che porta una tazza del cesso sulle spalle e dice:

" ieri ti ho fatto vedere il buco del culo, questa è la tazza del cesso, ora sto' rotolo di carta igienica me lo vuoi dare o no ???? "



a2000 è offline   Rispondi citando il messaggio o parte di esso
Old 20-11-2003, 11:01   #108
a2000
Bannato
 
L'Avatar di a2000
 
Iscritto dal: Jan 2001
Messaggi: 1976
Quote:
Originariamente inviato da lombardp
Parole, parole, parole... ma finora non ho visto nessun codice completo!

Fateli vedere questi algoritmi !!!
che impazienza, to' per ora solo il bulk:

Codice:
 i = 1: j = 5
 For k = 1 To iMax * jMax
  v(i, j) = 100
  Call ConnMin(i, j, 0, hMin, vMin)
  If vMin > 8 Then Exit For
  i = i + Di(hMin): j = j + Dj(hMin)
  For h = 1 To 8
   ih = i + Di(h): jh = j + Dj(h)   
   v(ih, jh) = v(ih, jh) - 1
  Next h
 Next k



Sub ConnMin(i, j, n, hMin, vMin)
 
 vMin = v(i + Di(1), j + Dj(1)): hMin = 1
 For h = 2 To 8
  vx = v(i + Di(h), j + Dj(h))
  If vx < vMin Then: vMin = vx: hMin = h
 Next h
 
End Sub
a2000 è offline   Rispondi citando il messaggio o parte di esso
Old 20-11-2003, 12:12   #109
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53967
Io credo di aver risolto con un algoritmo Greedy...
Devo fare un po' di compattazione...lo posto stesera
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 20-11-2003, 12:22   #110
NA01
Senior Member
 
L'Avatar di NA01
 
Iscritto dal: Jun 2003
Città: Genova
Messaggi: 5676
Quote:
Originariamente inviato da a2000
che impazienza, to' per ora solo il bulk:

Codice:
 i = 1: j = 5
 For k = 1 To iMax * jMax
  v(i, j) = 100
  Call ConnMin(i, j, 0, hMin, vMin)
  If vMin > 8 Then Exit For
  i = i + Di(hMin): j = j + Dj(hMin)
  For h = 1 To 8
   ih = i + Di(h): jh = j + Dj(h)   
   v(ih, jh) = v(ih, jh) - 1
  Next h
 Next k



Sub ConnMin(i, j, n, hMin, vMin)
 
 vMin = v(i + Di(1), j + Dj(1)): hMin = 1
 For h = 2 To 8
  vx = v(i + Di(h), j + Dj(h))
  If vx < vMin Then: vMin = vx: hMin = h
 Next h
 
End Sub

che è?
fortran o vb?

non i picchiare

ciao
NA01 è offline   Rispondi citando il messaggio o parte di esso
Old 20-11-2003, 12:42   #111
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53967
Anzi lo posto ora:
Codice:
#include <stdio.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>

#define DIM 10
#define SPOST 8

int valido(int x, int y, int ris[])
{
	if(x >= 0 && y >= 0 && y < DIM && x < DIM)
		if(!ris[x*DIM+y]) return 1;
	return 0;
}

int eval(int x, int y, int ris[])
{
    if(!valido(x,y,ris)) return 9;
	return 0+((valido(x-2, y-2, ris))?1:0)+((valido(x+2, y-2, ris))?1:0)
		+((valido(x-2, y+2, ris))?1:0)+((valido(x+2, y+2, ris))?1:0)
		+((valido(x-3, y, ris))?1:0)+((valido(x+3, y, ris))?1:0)
		+((valido(x, y-3, ris))?1:0)+((valido(x, y+3, ris))?1:0);
}

void stampaL(char l[])
{
	for(int i=0; i<DIM; ++i)
	{
		for(int j=0; j<DIM; j++)
			printf("%c",l[i*DIM+j]);
		printf("\n");
	}
}

int main(int argc, char *argv[])
{
    int min = 0, tx, ty, x = 0, y = 0, ris[DIM*DIM], i, j, tmp;
	int spostx[8] = {-3, 3, 0, 0 ,-2, 2,-2, 2};
	int sposty[8] = { 0, 0,-3, 3 ,-2,-2, 2, 2};
	char l[DIM*DIM];
    memset(ris, 0, DIM*DIM*sizeof(int));
    
    ris[x*DIM+y] = 1;
	
    for(i=1; i<DIM*DIM; ++i)
    {
		for(int h=0; h<DIM*DIM; ++h)
			if(ris[h] == 0)
				l[h] = '0';
			else
				l[h] = 'X';
			l[x*DIM+y] = 'A';
			min = 9;
			
			for(j=0; j<8; ++j)
			{	
				tmp = eval(x+spostx[j], y+sposty[j], ris);
				if(tmp < 9)
					l[(x+spostx[j])*DIM+y+sposty[j]] = '0' + tmp;
				
				if(tmp < min)
				{
					min = tmp;
					tx = x+spostx[j];
					ty = y+sposty[j];
				}
			}
			
			stampaL(l);
			x = tx;
			y = ty;
			ris[x*DIM+y] = i+1;
			printf("\n%d (%d,%d) min=%d\n",i+1, x, y, min);
			getchar();
			if(min == 9)
			{
				printf("\nerrore");
				break;
			}
    }
    
    for(i=0; i<DIM*DIM; ++i)
    {
        printf("%4d",ris[i]);
        if(!((i+1)%DIM))
			printf("\n");
    }
	
    getchar();
    return 0;
}
Questo stampa tutte i passi quindi posso ridurre ancora le righe...
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 20-11-2003, 12:43   #112
a2000
Bannato
 
L'Avatar di a2000
 
Iscritto dal: Jan 2001
Messaggi: 1976
Quote:
Originariamente inviato da NA01
che è?
fortran o vb?
uno e l'altro.
a2000 è offline   Rispondi citando il messaggio o parte di esso
Old 20-11-2003, 12:54   #113
a2000
Bannato
 
L'Avatar di a2000
 
Iscritto dal: Jan 2001
Messaggi: 1976
.

Ultima modifica di a2000 : 20-11-2003 alle 12:56.
a2000 è offline   Rispondi citando il messaggio o parte di esso
Old 20-11-2003, 12:57   #114
lombardp
Senior Member
 
L'Avatar di lombardp
 
Iscritto dal: Jun 2002
Città: Firenze
Messaggi: 630
Quote:
Originariamente inviato da a2000
che impazienza, to' per ora solo il bulk:
Molte grazie! Ora devo cercare di capirlo bene.

Dato che non conosco il linguaggio, ti chiedo solo una spiegazione "sintattica": EXIT FOR serve ad abortire il ciclo corrente, oppure tutto il FOR?
__________________
---> Lombardp
CSS Certified Expert (Master Level) at Experts-Exchange
Proud user of LITHIUM forum : CPU technology
Webmaster of SEVEN-SEGMENTS : Elettronica per modellismo
lombardp è offline   Rispondi citando il messaggio o parte di esso
Old 20-11-2003, 13:30   #115
a2000
Bannato
 
L'Avatar di a2000
 
Iscritto dal: Jan 2001
Messaggi: 1976
il ciclo corrente. nel caso specifico il ciclo in k.

la matrice v(i, j) è la matrice dei gradi di connessione residui di ogni singola cella.
è inizializzata a v(i, j) = 8 ad eccezione delle fasce di bordo. inoltre è orlata (con valore singolare = 100 ) in modo da evitare il ceck di validità degli spostamenti.

1) ad ogni passo si effettua lo spostamento (consentito) sulla cella con il minor valore di connessione

2) si aggiorna il valore di connessione di tutte le celle connesse alla cella prescelta

con un artificio (valori negativi) la stessa matrice viene utilizzata per tenere memoria degli spostamenti (da 1 a 8).

per ogni elemento di v(i,j) potrebbe bastere mezzo byte (4 bit).

la subroutine di ricerca del minimo ConnMin diventa ricursiva a n passi se si vuole discriminare tra due valori di minimo uguali in base ai passi successivi.

Ultima modifica di a2000 : 20-11-2003 alle 13:34.
a2000 è offline   Rispondi citando il messaggio o parte di esso
Old 20-11-2003, 13:47   #116
a2000
Bannato
 
L'Avatar di a2000
 
Iscritto dal: Jan 2001
Messaggi: 1976
Quote:
Originariamente inviato da /\/\@®¢Ø
Purtroppo per ora non ho tempo da dedicare al gioco, pero' posso offrirti la mia variante della funzione arcobaleno
Versione python

Codice:
 color = ['red','orange','yellow','green','blue']
n = len(color)

def arcobaleno( str ):
    result = ''
    for i in range(0,len(str) ):
        result += "[ccolor=" + color[i%n] + "]" + str[i] + "[/ccolor]"
    return result
(in python sono alle prime armi, quindi prendetela con le pinze )

Per le cose serie dovrai aspettare un po' di piu' temo

beh,sefaiachicel'hapiùcorto:



Codice:
Function f_arcobaleno(a$) As String
 
 c$ = "red   orangeyellowgreen blue  "
 For i% = 1 To Len(a$)
  f_arcobaleno = f_arcobaleno + "[ccolor=" + Trim$(Mid$(c$, (i% Mod 5) * 6 + 1, 6)) + "]" + Mid$(a$, i%, 1) + "[/ccolor]"
 Next i%

End Function

Ultima modifica di a2000 : 21-11-2003 alle 10:08.
a2000 è offline   Rispondi citando il messaggio o parte di esso
Old 20-11-2003, 14:02   #117
lombardp
Senior Member
 
L'Avatar di lombardp
 
Iscritto dal: Jun 2002
Città: Firenze
Messaggi: 630
Ti dico cosa ero arrivato a dedurre dal codice:

Quote:
Originariamente inviato da a2000
la matrice v(i, j) è la matrice dei gradi di connessione residui di ogni singola cella.
è inizializzata a v(i, j) = 8 ad eccezione delle fasce di bordo. inoltre è orlata (con valore singolare = 100 ) in modo da evitare il ceck di validità degli spostamenti.
Non ero arrivato a capire che V era la matrice degli "spostamenti residui", per ora avevo concluso che era una matrice di "pesi" che erano decrementati sulle caselle adiacenti (nel senso degli spostamenti) a quella corrente.

Quindi non ero arrivato a definire che era diversa nelle fasce di bordo (ci sono meno collegamenti), ma ero arrivato alla conclusione dell'orlatura per evitare il "boundary checking".

Quote:
1) ad ogni passo si effettua lo spostamento (consentito) sulla cella con il minor valore di connessione

2) si aggiorna il valore di connessione di tutte le celle connesse alla cella prescelta
Ok, si capiva bene dal codice.

Quote:
con un artificio (valori negativi) la stessa matrice viene utilizzata per tenere memoria degli spostamenti (da 1 a 8).

per ogni elemento di v(i,j) potrebbe bastere mezzo byte (4 bit).
Questo non solo non lo avevo minimamente immaginato, ma anche adesso non riesco a vederlo... è in un'altra porzione di codice?
__________________
---> Lombardp
CSS Certified Expert (Master Level) at Experts-Exchange
Proud user of LITHIUM forum : CPU technology
Webmaster of SEVEN-SEGMENTS : Elettronica per modellismo
lombardp è offline   Rispondi citando il messaggio o parte di esso
Old 20-11-2003, 15:15   #118
verloc
Senior Member
 
L'Avatar di verloc
 
Iscritto dal: Jan 2000
Messaggi: 549
Che era il "traveling salesman" lo avevo capito da parecchio.
Solo che sono onesto e volevo comunque arrivare a una mia soluzione.
Soluzione comunque basata sulle primissime indicazioni di a2000(mi sun' unest').

Devo ricredermi sulla possibilità di non ricorrere a strutture(nodo),per un codice + compatto)

Si costrusce la matrice mxn di nodi (inizializzati allo stato non visitato).
Si fa una funzione "visita"che ha come parametro il reference al nodo(per fare +veloce) e che restituisce il nodo successivo secondo il criterio di ottimizzazione.

...almeno credo
verloc è offline   Rispondi citando il messaggio o parte di esso
Old 20-11-2003, 15:19   #119
verloc
Senior Member
 
L'Avatar di verloc
 
Iscritto dal: Jan 2000
Messaggi: 549
Sono tutti algoritmi di "Network traversal "

Quello + famoso (e + difficile) è quello che deve trovare il percorso minimimo per visitare tutte le "città" una sola volta tornando a quella di partenza.
(scannatevi )
verloc è offline   Rispondi citando il messaggio o parte di esso
Old 20-11-2003, 15:33   #120
cn73
Senior Member
 
L'Avatar di cn73
 
Iscritto dal: Jul 1999
Città: Torino
Messaggi: 2221
coinci è davvero impressionante la velocità del tuo algoritmo! la 10 X 10 viene praticamente restituita istantaneamente...l'ho fatto girare su un vecchio server Unix via telnet...
cn73 è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Recensione realme 12+: sfida la fascia media con un design unico e un display luminosissimo Recensione realme 12+: sfida la fascia media con...
OnePlus Pad Go: un tablet economico perfetto per l'intrattenimento. La recensione OnePlus Pad Go: un tablet economico perfetto per...
Per Huawei l’IA è una questione di storage. Presentate soluzioni dedicate e un SSD da 128 TB Per Huawei l’IA è una questione di storag...
Recensione Google Pixel Tablet: in ritardo ma un ottimo primo passo! Recensione Google Pixel Tablet: in ritardo ma un...
ASUS ProArt PA32UCXR: 4K, Quantum Dot e Mini-LED i per professionisti dell'immagine ASUS ProArt PA32UCXR: 4K, Quantum Dot e Mini-LED...
Gemini per Google Workspace: in arrivo t...
Gemini si prepara a capire meglio ci&ogr...
Google riprogetta il suo motore di ricer...
Google Foto si rinnova con l'intelligenz...
Nuovo rinvio per la navicella Boeing CST...
Una campagna malware ha preso di mira si...
Novità in AWS: Adam Selipsky lasc...
Red Dead Redemption: la versione PC del ...
La Sondors Metacycle non è mai stata leg...
Microsoft Places, l'intelligenza artific...
VESA annuncia le nuove specifiche Displa...
Anthropic Claude in Europa: l'assistente...
Panasonic presenta la gamma TV 2024: pan...
BYD lancia la Sea Lion 07, nuova elettri...
L'iPhone 15 è sceso a 749 euro: ecco tut...
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: 23:21.


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