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

本文介绍了一个C#实现的学生信息列表的排序和查找方法,包括按序号、姓名、性别进行升序和降序排序,并展示了如何使用Find、FindAll及Exists方法查找特定条件的学生。

转载自:http://www.cnblogs.com/dooroo/archive/2012/12/11/2813858.html

先建一个学生类:

复制代码
        public class student
        {
            public int Number { get; set; }
            public string Name { get; set; }
            public bool Sex { get; set; }
            public student(int _number, string _name, bool _sex)
            {
                Number = _number;
                Name = _name;
                Sex = _sex;
            }
            public override string ToString()
            {
                return string.Format("序号:{0},姓名:{1},性别:{2}",
                    Number.ToString(), Name, Sex ? "" : "");
            }
        }
复制代码

例程代码如下:

复制代码
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Windows.Forms;

namespace ListSortTest
{
    public partial class Form1 : Form
    {
        public Form1()
        {
            InitializeComponent();
        }

        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 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 showList(List<student> _list)
        {
            for (int i = 0; i < _list.Count; i++)
            {
                richTextBox1.Text += _list[i].ToString() + "\r\n";
            }
        }

        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();

        }
    }
}
复制代码

通过以上代码测试,排序效果如下:

其它功能显示如图(欢迎访问http://www.cnblogs.com/dooroo)


### 通达信 EXIST 函数 使用说明 在通达信技术分析平台中,`EXIST` 函数用于判断某个条件是否在指定的时间范围内存在。其基本语法如下: #### 基本语法 ```plaintext EXIST(表达式, N) ``` - **参数解释**: - `表达式`: 需要检测的布尔条件或数值表达式。 - `N`: 时间范围,表示向前回溯的天数。 - **返回值**: 如果在过去 `N` 天内至少有一天满足给定的 `表达式`,则返回 `True`;否则返回 `False`。 此函数类似于其他编程语言中的“是否存在”的逻辑操作,在金融数据分析中常用来确认某些特定事件的发生情况[^2]。 --- #### 示例代码及其含义 以下是几个常见的使用场景和对应的示例代码: 1. **判断过去 10 日内是否有阳线** ```plaintext EXIST(CLOSE > OPEN, 10) ``` 上述语句的作用是检查最近 10 个交易日内是否存在收盘价大于开盘价的情况(即阳线)。如果存在,则返回 True;否则返回 False。 2. **判断某只股票在过去 20 日内是否突破过某一价格水平** 假设我们希望知道该股在过去 20 日内是否曾高于 10 元: ```plaintext EXIST(HIGH > 10, 20) ``` 3. **结合复杂条件** 可以通过组合多个条件来增强功能。例如,判断过去 50 日内是否出现成交量超过平均成交量两倍的日子: ```plaintext EXIST(VOLUME > MA(VOLUME, 50) * 2, 50) ``` 4. **与其他函数配合** 结合均线系统可以构建更复杂的交易信号。比如,寻找过去 30 日内股价曾经站在短期均线上方的情形: ```plaintext EXIST(CLOSE > MA(CLOSE, 10), 30) ``` 以上这些例子展示了如何灵活运用 `EXIST` 函数完成各种时间序列上的条件筛选任务[^2]。 --- ### 注意事项 当实际应用时需要注意以下几点: - 参数顺序不可颠倒,第一个必然是待验证的逻辑或者数值表达式,第二个才是周期长度; - 对于初学者来说容易混淆的是日期跨度是从当前往前推算而非往后延伸; - 在编写较为复杂的策略模型时候建议先单独测试各个子模块确保无误后再整体组装运行调试效率更高一些。 --- ### 关联知识点补充 除了本文介绍的内容外,还可以进一步了解与其类似的函数如 `COUNT`, 它们虽然形式接近但侧重点各有不同。另外关于具体实现细节方面如果有兴趣也可以深入研究底层算法原理部分[^3]。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值