c#,将程序更改为线性搜索

c#, Changing program to linear search

几天前我编写了这段代码,有一个非常简单的问题。我知道有人问过这样的问题,但我找不到任何适合我的案例的东西。我想把案例3中的搜索功能改成不太复杂的搜索方式,所以基本上想换成线性搜索。如果那不可能,我想在其他地方实现线性搜索。你们有什么线索吗?感谢所有帮助。

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.IO;

namespace Loggbok
{
    class MainClass
    {
        public static void Main(string[] args)
        {
            DateTime tiden = DateTime.UtcNow;//Skriver ut tiden vid varje inlägg
            bool running = true;//Ger ett booleskt värde till variabeln running för att kunna skapa en loop
            List<string[]> loggbok = new List<string[]>();//Här skapas listan som innehåller arrayen

        while (running)//Här skapas loopen
        {
            Console.WriteLine("\n************************************");
            Console.WriteLine("\nVälkommen till loggboken!");
            Console.WriteLine("\n************************************");
            Console.WriteLine("\n[1] Skriv nytt inlägg i loggboken");
            Console.WriteLine("[2] Skriv ut alla loggar");
            Console.WriteLine("[3] Sök inlägg i loggboken");
            Console.WriteLine("[4] Radera innehåll i loggboken");
            Console.WriteLine("[5] Avsluta loggboken");
            Console.WriteLine("\n************************************");
            Console.Write("\nVälj: ");

            int option;//Int eftersom valet ska vara ett heltal

            try
            {
                option = Int32.Parse(Console.ReadLine());//testar så att inmatningen är av typen Int

            }
            catch
            {
                Console.WriteLine("Fel, du får bara skriva in nummer");//Felmeddelande om inmatningen är en bokstav
                continue;
            }

            switch (option)
            {
                case 1:
                    string[] logg = new string[2];//Här deklareras arrayen
                    Console.WriteLine("\n************************************");
                    Console.WriteLine(tiden);
                    Console.WriteLine("Ange en Titel:");
                    logg[0] = Console.ReadLine();//Här sparas titeln
                    Console.Clear();
                    Console.WriteLine("\n************************************");
                    Console.WriteLine("Skriv inlägg:");
                    logg[1] = String.Format("{0}{1}{2}", Console.ReadLine(), Environment.NewLine, DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss"));//Här sparas inlägget samt datum och tid, detta är möjligt tack vare formattering 
                    loggbok.Add(logg);
                    break;


                case 2:
                    foreach (string[] item in loggbok)//För att skriva ut alla items i loggboken
                    {
                        Console.WriteLine("\n--------------------------------------\n ");
                        Console.WriteLine(item[0]);//För att skriva ut titel
                        Console.WriteLine(item[1]);//För att skriva ut inlägg
                        Console.WriteLine("\n--------------------------------------\n ");
                    }
                    Console.ReadLine();
                    break;




                case 3:

                    Console.WriteLine("\n************************************");
                    Console.WriteLine("Skriv in ett ord du vill söka efter i loggboken:");
                    var nyckelord = Console.ReadLine();//Här sparas inmatningen av nyckelordet
                    var entries = loggbok.Where(entry => entry.Any(item =>item.IndexOf(nyckelord, StringComparison.OrdinalIgnoreCase) > -1));//För att kontrollera om nyckelordet finns samt ignorera skiftlägeskänslighet, och finna både titel och inlägg
                    foreach (var entry in entries)//för att finna alla inlägg/titlar som matchar nyckelord
                    {
                        Console.WriteLine("\n--------------------------------------\n ");
                        Console.WriteLine(string.Join(", ", entry));//Skriver ut titel samt inlägg som matchat nyckelordet
                        Console.WriteLine("\n--------------------------------------\n ");
                    }
                    if (entries.Count() == 0)//Om ingen matchning hittas
                    {
                        Console.WriteLine("\n--------------------------------------\n ");
                        Console.Write("Din sökning misslyckades...");//Felmeddelande om ingen matchning hittas
                        Console.WriteLine("\n--------------------------------------\n ");
                    }
                    break;



                case 4:

                    Console.WriteLine("\n************************************");
                    Console.WriteLine("Skriv titeln på det inlägg du vill ta bort:");
                    string title = Console.ReadLine();//Sparar titeln på inlägget användaren vill radera

                    for (int x = 0; x < loggbok.Count; x++) //Loopa igenom varje titel
                    {
                        if (String.Equals(loggbok[x][0], title, StringComparison.OrdinalIgnoreCase)) //Icke skiftlägeskänslig matchning av titeln.
                        {
                            loggbok.RemoveAt(x); //Matchning funnen.
                        }
                        else
                        {
                            Console.WriteLine("Titeln finns inte, återgår till huvudmenyn");
                        }


                    }
                    break; //Avsluta loopen.


                case 5:

                    running = false;//Avslutar loopen och därmed programmet
                    break;


                default:

                    Console.WriteLine("Nu blev det fel, välj mellan [1] [2] [3] [4] [5]");//Felmeddelande om valet är någon annan siffra än de som menyn innehåller
                    break;









            }
        }
    }
}

}

案例 3 中的关键字搜索已经是线性的。您是否只是想让 switch 中的搜索语句不那么冗长?然后把搜索表达式变成函数:

static IEnumerable<string[]> SearchByKeyword(IEnumerable<string[]> loggbok,
  string nyckelord) {
  return loggbok.Where(entry => entry
    .Any(item => item.IndexOf(nyckelord, 
      StringComparison.OrdinalIgnoreCase) > -1));
}

并在 switch 语句中调用它:

var entries = SearchByKeyword(loggbok, nyckelord);