In C#, qual è il modo più veloce per cercare elementi in un elenco ma fare una ricerca "startWith ()"?

StackOverflow https://stackoverflow.com/questions/19849923

Domanda

Ho un elenco di stringhe:

 var list = new List<string>();
 list.Add("CAT");
 list.Add("DOG");

var listofItems = new List<string>();
 listofItems .Add("CATS ARE GOOD");
 listofItems .Add("DOGS ARE NICE");
 listofItems .Add("BIRD");
 listofItems .Add("CATAPULT");
 listofItems .Add("DOGGY");

E ora voglio una funzione come questa:

 listofItems.Where(r=> list.Contains(r));

Ma invece di contenere, voglio che faccia un inizio con il controllo, quindi verranno restituiti 4 su 5 articoli (Bird no).

Qual è il modo più veloce per farlo?

È stato utile?

Soluzione

Puoi usare Inizia con All'interno di un Qualunque

listofItems.Where(item=>list.Any(startsWithWord=>item.StartsWith(startsWithWord)))

Puoi visualizzarlo come un doppio for Loop, con il secondo for scoppiare non appena colpisce un true Astuccio

var filteredList = new List<String>();
foreach(var item in listOfItems)
{
    foreach(var startsWithWord in list)
    {
        if(item.StartsWith(startsWithWord))
        {
            filteredList.Add(item)
            break;
        }
    }
}
return filteredList;

Altri suggerimenti

Il modo più veloce sarebbe l'uso di un'altra struttura di dati, ad esempio Trie. L'implementazione di base C# è disponibile qui: https://github.com/kpol/trie

Questo dovrebbe darti ciò di cui hai bisogno in un formato più semplificato:

 var result = listofItems.Select(n =>
 {
      bool res = list.Any(v => n.StartsWith(v));
      return res 
               ? n 
               : string.Empty;
 }).Where(b => !b.Equals(string.Empty));

La struttura dei dati di Trie è ciò di cui hai bisogno. Dai un'occhiata a questa biblioteca più matura: Trienet

using Gma.DataStructures.StringSearch;

...

var trie = new SuffixTrie<int>(3);

trie.Add("hello", 1);
trie.Add("world", 2);
trie.Add("hell", 3);

var result = trie.Retrieve("hel");
Autorizzato sotto: CC-BY-SA insieme a attribuzione
Non affiliato a StackOverflow
scroll top