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

[转]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
内容概要:本文系统介绍了算术优化算法(AOA)的基本原理、核心思想及Python实现方法,并通过图像分割的实际案例展示了其应用价值。AOA是一种基于种群的元启发式算法,其核心思想来源于四则运算,利用乘除运算进行全局勘探,加减运算进行局部开发,通过数学优化器加速函数(MOA)和数学优化概率(MOP)动态控制搜索过程,在全局探索与局部开发之间实现平衡。文章详细解析了算法的初始化、勘探与开发阶段的更新策略,并提供了完整的Python代码实现,结合Rastrigin函数进行测试验证。进一步地,以Flask框架搭建前后端分离系统,将AOA应用于图像分割任务,展示了其在实际工程中的可行性与高效性。最后,通过收敛速度、寻优精度等指标评估算法性能,并提出自适应参数调整、模型优化和并行计算等改进策略。; 适合人群:具备一定Python编程基础和优化算法基础知识的高校学生、科研人员及工程技术人员,尤其适合从事人工智能、图像处理、智能优化等领域的从业者;; 使用场景及目标:①理解元启发式算法的设计思想与实现机制;②掌握AOA在函数优化、图像分割等实际问题中的建模与求解方法;③学习如何将优化算法集成到Web系统中实现工程化应用;④为算法性能评估与改进提供实践参考; 阅读建议:建议读者结合代码逐行调试,深入理解算法流程中MOA与MOP的作用机制,尝试在不同测试函数上运行算法以观察性能差异,并可进一步扩展图像分割模块,引入更复杂的预处理或后处理技术以提升分割效果。
### 通达信 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、付费专栏及课程。

余额充值