[C#]List的Sort()、Find()、FindAll()、Exist()的使用方法举例

简介: [转]http://www.cnblogs.com/dooroo/archive/2012/12/11/2813858.html public class student { //构造函数 public student(int _number, ...

[转]http://www.cnblogs.com/dooroo/archive/2012/12/11/2813858.html

 public class student
    {
        //构造函数
        public student(int _number, string _name, bool _sex)
        {
            Number = _number;
            Name = _name;
            Sex = _sex;
        }
        public int Number { get; set; }
        public string Name { get; set; }
        public bool Sex { get; set; }

        public override string ToString()
        {
            return string.Format("序号:{0},姓名:{1},性别:{2}", Number.ToString(), Name, Sex ? "" : "");
        }

    }
 List<student> Students = new List<student>();
        private void Form1_Load(object sender,EventArgs e)
        {
            Students.Add(new student(1, "张一", true));
            Students.Add(new student(3, "张二", false));
            Students.Add(new student(5, "张三", true));
            Students.Add(new student(2, "张四", false));
            Students.Add(new student(4, "张五", true));
            Students.Add(new student(6, "张六", false));
        }

       
        private void showList(List<student> _list)
        {
            foreach(var item in _list)
            {
                richTextBox1.Text += item.ToString() + "\r\n";
            }
        }

        private void button1_Click(object sender, EventArgs e)
        {
            richTextBox1.Text += "**原始显示:\r\n";
            showList(Students);

            richTextBox1.Text += "\r\n**用序号排序从小到大显示:\r\n";
            Students.Sort((x, y) => x.Number < y.Number ? -1 : 0);
            showList(Students);

            richTextBox1.Text += "\r\n**用序号排序从大到小显示:\r\n";
            Students.Sort((x, y) => x.Number > y.Number ? -1 : 0);
            showList(Students);

            richTextBox1.Text += "\r\n**用姓名排序(升序)显示:\r\n";
            Students.Sort((x, y) => x.Name.CompareTo(y.Name));
            showList(Students);

            richTextBox1.Text += "\r\n**用姓名排序(降序)显示:\r\n";
            Students.Sort((x, y) => y.Name.CompareTo(x.Name));
            showList(Students);

            richTextBox1.Text += "\r\n**用性别排序(升序)显示:\r\n";
            Students.Sort((x, y) => x.Sex.CompareTo(y.Sex));
            showList(Students);
        }

        private void button2_Click(object sender, EventArgs e)
        {
            richTextBox1.Text += "\r\n**找出Name=\"张四\"的学生:\r\n";
            richTextBox1.Text += Students.Find((student s) => s.Name == "张四").ToString();

            richTextBox1.Text += "\r\n\r\n**找出第一个男学生:";
            richTextBox1.Text += "(该方法只会找到第一个就停止)\r\n";
            richTextBox1.Text += Students.Find((student s) => s.Sex == true).ToString();

            richTextBox1.Text += "\r\n\r\n**找出所有女学生:\r\n";
            showList(Students.FindAll((student s) => s.Sex == false));

            richTextBox1.Text += "\r\n\r\n**判断“张四”学生是否存在:\r\n";
            richTextBox1.Text += Students.Exists((student s) => s.Name == "张四" ? true : false).ToString();
        }

 

学习交流群:364976091
相关文章
|
6月前
|
安全 C#
C# List基本用法
C# List基本用法
|
存储 C++ 容器
【C++: list的使用方法(总结)】
【C++: list的使用方法(总结)】
111 1
|
6月前
|
C#
C#中sort排序相关用法介绍
C#中sort排序相关用法介绍
|
6月前
|
存储 C# 索引
C# | 比较IEnumerable、List、数组
IEnumerable`定义了一组用于枚举集合的方法,包括`GetEnumerator`方法,该方法返回一个实现了`IEnumerator`接口的对象,用于枚举集合中的每个元素。`List`和数组都可以使用`foreach`循环来遍历其中的元素,这是因为它们都实现了`IEnumerable`接口。 由于数组在内存中开辟了一段连续的空间,因此可以直接通过索引访问元素,访问速度很快。而 List 则需要通过指针或引用来访问元素,速度相对较慢。 由于数组的大小是固定的,当需要添加或删除元素时,需要重新创建一个新数组,将原数组中的元素复制到新数组中,并添加或删除元素。
214 0
C# | 比较IEnumerable、List、数组
|
6月前
|
C++ 容器
【C++】STL容器——探究List与Vector在使用sort函数排序的区别(14)
【C++】STL容器——探究List与Vector在使用sort函数排序的区别(14)
C#List与ArrayList,Hashtable与Dictionary总结
C#List与ArrayList,Hashtable与Dictionary总结
51 0
C#List与ArrayList,Hashtable与Dictionary总结
|
搜索推荐 算法 C#
C#选择排序(Selection Sort)算法
C#选择排序(Selection Sort)算法
|
安全 C# 索引
C# 泛型集合和非泛型集合(List ArrayLIst)
C# 泛型集合和非泛型集合(List ArrayLIst)
105 0
|
存储 安全 C#
C#里面的不同集合(数组、ArrayList集合、List泛型)
在内存中连续存储,因此可以快速而容易地从头到尾遍历元素,可以快速地修改元素
|
算法 C++
SGI-STL源码剖析之list::sort()
SGI-STL源码剖析之list::sort()
110 0