Torna indietro   Hardware Upgrade Forum > Software > Programmazione

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
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 ti seguono, anche con gimbal integrata
Le webcam Insta360 Link 2 Pro e Link 2C Pro sono una proposta di fascia alta per chi cerca qualità 4K e tracciamento automatico del soggetto senza ricorrere a configurazioni complesse. Entrambi i modelli condividono sensore, ottiche e funzionalità audio avanzate, differenziandosi per il sistema di tracciamento: gimbal a due assi sul modello Link 2 Pro, soluzione digitale sul 2C Pro
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 15-06-2011, 09:46   #1
Kralizek
Senior Member
 
L'Avatar di Kralizek
 
Iscritto dal: Feb 2003
Città: Stockholm (SE)
Messaggi: 1343
[C#/Vari] - Merge di N alberi con mapping table

Prima di tutto, ho taggato il topic come "vari" perché mi interessa anche un semplice consiglio algoritmico, al di lá della pura implementazione in C#.

Problema:
nel database ho una view che é composta dai field ( IndexID, PlaceID, Name, ParentID, SiteID ) e che, per ciascun valore di IndexID, puó contenere diversi alberi univoci per SiteID.
in breve, un Index puó essere genereato da diversi Site e ogni Site ha il suo proprio albero (di fatto esiste una "Stoccolma" per ciascun Site).

Ora sto scrivendo una funzione che, per ciascun Index, dati gli alberi di ciascun Site, genera un unico albero utilizzando una tabella di mapping.

La logica del merge dovrebbe essere la seguente:
- se il nodo C1 é mappato al nodo D1, si usa il nodo D1 e si attaccano i figli del nodo C1 al nodo D1

fin qui tutto facile vero?

bene, ora considerate questo, il nodo C13 (ovvero il terzo sottonodo del nodo C1), puó essere mappato al nodo D2. In questo caso deve essere rimosso dalla lista dei sottonodi D1.

Piú interessante ora vero?

Ed ora del sano codice.

Iniziamo con le classi "contenitore"

Spoiler:
Codice:
public class PlaceRow
{
	public int IndexID { get; set; }
	public int PlaceID { get; set; }
	public string Name { get; set; }
	public int? ParentID { get; set; }
	public int SiteID { get; set; }
}

public class Place 
{
	public int ID { get; set; }
	public string Name { get; set; }
	public IEnumerable<Place> Places { get; set; }
}

public class Mapping
{
	public int SourceID { get; set; }
	public int DestinationID { get; set; }
}


Riporto una versione "concettuale" del Main

Codice:
void Main()
{
	IEnumerable<PlaceRow> placeRows = GetPlaceRows(93);
	
	IEnumerable<IEnumerable<Place>> placeTrees = LoadTrees(placeRows);
	
	IEnumerable<Mapping> mappings = GetMappings();
	
	IEnumerable<Place> mergedTrees = MergeTrees(placeTrees, mappings);
}
ovviamente il tutto sta nella funzione MergeTrees.

Codice:
public IEnumerable<Place> MergeTrees (IEnumerable<IEnumerable<Place>> places, IEnumerable<Mapping> mappings)
{
	var map = mappings.ToDictionary(k => k.SourceID, v => v.DestinationID);
	throw new NotImplementedException("Epic fail");
}
come giá detto, non é che sto a chiedere codice. Mi basta qualche suggerimento sull'algoritmo da seguire.

La prima parte é banale. Per ciascuna lista, la si cicla e si controlla se qualche elemento é mappato. nel caso si aggiunge la lista di sottonodi al nodo di destinazione.

Il problema é con i sottonodi mappati :S

Grazie
Kralizek è offline   Rispondi citando il messaggio o parte di esso
Old 15-06-2011, 14:25   #2
Kralizek
Senior Member
 
L'Avatar di Kralizek
 
Iscritto dal: Feb 2003
Città: Stockholm (SE)
Messaggi: 1343
Risolto! Cambiando totalmente approccio il problema era letteralmente banale.

Codice:
void Main()
{
	IEnumerable<PlaceRow> placeRows = GetPlaceRows(93);
	
	IEnumerable<Mapping> mappings = GetMappings();
	
	IEnumerable<PlaceRow> mergedRows = MergeRows(placeRows, mappings);

	IEnumerable<Place> placeTree = LoadTrees(mergedRows);
}

public IEnumerable<Place> LoadTrees(IEnumerable<PlaceRow> rows)
{
	Func<PlaceRow, ILookup<int?, PlaceRow>, Place> transform = null;
	
	transform = (row, grp) => 
	{
		Place place = new Place 
		{
			ID = row.PlaceID,
			Name = row.Name,
			Places = from gr in grp[row.PlaceID]
						select transform(gr, grp)
		};
		
		return place;
	};
	
	var lookup = rows.ToLookup( k=> k.ParentID);
	
	return from row in lookup[null]
			select transform(row, lookup);
}

public IEnumerable<PlaceRow> MergeRows(IEnumerable<PlaceRow> rows, IEnumerable<Mapping> mappings)
{
	var map = mappings.ToDictionary(k => k.SourceID, v => v.DestinationID);

	List<PlaceRow> newRowSet = new List<PlaceRow>();
	
	foreach (var row in rows)
	{
		if (!map.ContainsKey(row.PlaceID))
		{
			newRowSet.Add(row);
			
			if (row.ParentID.HasValue && map.ContainsKey(row.ParentID.Value))
				row.ParentID = map[row.ParentID.Value];
		}
	}
	
	return newRowSet;
}
Come potete vedere, lavorando sui dati estratti dal database anzicché sugli alberi, la situazione é molto piú facile da gestire

In realtá mentre lo commentavo con un collega, per un nanosecondo avevo intravisto uno scenario non gestito. Ma me lo sono perso

Ultima modifica di Kralizek : 15-06-2011 alle 14:29.
Kralizek è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


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...
Display, mini PC, periferiche e networking: le novità ASUS al CES 2026 Display, mini PC, periferiche e networking: le n...
La nave elettrica più grande mai ...
Spusu lancia il Wi-Fi Calling: come funz...
Questo robot impara a muovere le labbra ...
iPhone 17 annienta la concorrenza in Cin...
La nuova Xiaomi SU7 batte un record: 4.2...
È possibile copiare i qubit: dei ...
BYD alza ulteriormente l'asticella: batt...
Il nuovo razzo spaziale riutilizzabile c...
L'ex leader di Assassin's Creed porta Ub...
Il razzo spaziale NASA SLS e la capsula ...
Samsung Galaxy S26 Ultra: quattro colora...
AWS investe 1,2 miliardi in Italia. Coin...
La navicella cinese Shenzhou-20 con il f...
I piani Business ed Education di Google ...
Ceres-2 e Lunga Marcia 3B: la Cina falli...
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: 05:46.


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