本文要学习的主题是使用List集合的where()方法和LINQ编写一个C#程序,以查找名字以'S'开头的学生名单。
语言集成查询又名 LINQ 用于生成 C# 语言查询。以前我们必须使用其他关系语言,例如 SQL 和 XML。它为 C# 语言或任何其他 .NET 语言提供了更多功能。在 LINQ 中查询数据库的语法与查询数组中存储的数据的语法相同。
在我们继续并理解C#程序的算法和代码之前,使用LINQ的List Collection的where()方法找到名字以'S'开头的学生列表。让我们简要复习一下LINQ的简写形式。
一个叫做LINQ的.NET框架的一部分使用户以类型安全的方式更容易地检索数据。这是在.NET 3.5版本中引入的。
LINQ最好的特点是它提供了一种从许多来源(包括数据库和XML文档)获取数据的单一方法。借助LINQ,用户可以编写更易于理解、更简洁、更美观的代码。它还提供其他功能,如过滤、排序、分组数据甚至修改数据。
现在,是时候对where()方法进行一些解释了,它也被称为Enumerable.Where()方法,属于命名空间System.Linq。
这个方法属于命名空间 System.Linq。它根据谓词对值序列进行过滤。让我们来看一下它的定义语法 -
public static System.Collections.Generic.IEnumerable<TSource> Where<TSource> (this System.Collections.Generic.IEnumerable<TSource> source, Func<TSource,bool> predicate);
这个方法有一个类型参数TSource,它告诉我们源的元素的类型。另外还有两个参数,源是一个IEnumerable8742468051c85b06f0a0af9e3e506b5c用于过滤,谓词是用来测试每个元素是否满足条件的函数。
这是一个返回满足条件的输入序列中的项目集合的返回方法,表示为一个IEnumerable8742468051c85b06f0a0af9e3e506b5c。当谓词或源为空时,可能会抛出ArgumentNullException异常。
我们将采取一个问题陈述,这将使我们很容易理解 where() 的概念方法。
在一所学校里,有一个由来自不同班级的5名成员组成的国际象棋队。他们分别是Ankit、Abhinay、Shubham、Shreyank和Shahnawaz。他们在不同的班级学习。需要提供一个带有首字母为'S'的西装外套。因此,为了知道以'S'开头的学生的姓名,校长委托你编写一个选择以'S'开头的学生姓名的程序。
现在,在下一节中,我们将讨论使用 LINQ 列表集合的 where() 方法编写 C# 程序来查找姓名以 'S' 开头的学生列表的算法。
以下是使用where()方法编写程序代码时需要遵循的步骤。
步骤 1 - 记得声明使用 where() 方法的正确命名空间,即 System.Linq。
第 2 步− 启动班级代码并声明三个变量来存储学生的卷号、班级和姓名。
第 3 步− 在下一步中,我们创建字符串方法,该方法返回学生的卷号、姓名和标准。
第 4 步− 在 main() 部分中,我们声明列表变量,然后将数据添加到列表中。
第五步 − 现在我们使用where()方法根据用户提供的谓词来过滤所需的信息。
第6步 − 在这一步中,我们显示获取到的详细信息。然后结束程序。
示例
让我们通过一个例子来讨论这个问题。
using System.Linq; using System; using System.Collections.Generic; using System.Threading.Tasks; using System.Text; class Student{ // Three variables to store roll number, class, and name of the student int roll; int std; string name; // Creating the string method which returns roll number, name, and standard of student public override string ToString(){ return roll + " " + name + " " + std; } static void Main(string[] args){ // Declaring a list variable List<Student> student = new List<Student>(){ // Details of students of the chess team new Student{ roll = 21, name = "Ankit", std = 10 }, new Student{ roll = 12, name = "Abhinay", std = 10 }, new Student{ roll = 07, name = "Shubham", std = 11 }, new Student{ roll = 14, name = "Shreyank", std = 12 }, new Student{ roll = 10, name = "Shanawaz", std = 11 } }; // Using the Where() function we search through the student details IEnumerable<Student> Query = student.Where(s => s.name[0] == 'S'); // Displaying the student details Console.WriteLine("Roll Name Standard"); Console.WriteLine("- - - - - - - - - - - - - - - - - "); foreach (Student e in Query) { // Call the to string method Console.WriteLine(e.ToString()); } } }
Roll Name Standard - - - - - - - - - - - - - - - - - 07 Shubham 11 14 Shreyank 12 10 Shanawaz 11
where() 方法的时间复杂度是常数,用 Big-O 表示法可以称为 O(1)。因此整个代码的时间复杂度为O(1)。
在本文中,我们讨论了一个 C# 程序,该程序使用 LINQ 的列表集合的 where() 方法查找姓名以“S”开头的学生列表。我们理解了 where() 方法。然后我们了解了算法,最后我们学习了代码。然后我们就了解了代码的时间复杂度。
我们希望本文对增强您对 C# 的了解有所帮助。
以上是C# 程序使用使用 LINQ 的列表收集的 where() 方法查找姓名以'S”开头的学生列表的详细内容。更多信息请关注PHP中文网其他相关文章!