C#学习笔记(29)——Linq的实现,Lambda求偶数和水仙花数
说明(2017-11-22 18:15:48):
1. Lambda表达式里面用了匿名委托,感觉理解起来还是挺难的。求偶数的例子模拟了Linq查询里的一个where方法。
2. 蒋坤说求水仙花数那个例子,“能看就看,看不懂就算了!”T_T
Linq方法求偶数:
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text; namespace _00_Test
{
class Program
{
static void Main(string[] args)
{
//Linq方法求偶数
int[] nums = { , , , , , , , , , };
List<int> list = new List<int>();
//where关键字
foreach (int n in nums.Where(e => e % == ))
{
Console.WriteLine(n);
}
Console.ReadKey();
}
}
}
模拟Linq方法:
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text; namespace _00_Test
{
public delegate bool MyDel(int n);
class Program
{
static void Main(string[] args)
{
int[] nums = { , , , , , , , , , };
int[] ns = MyWhere(nums, e => e % == );
Console.ReadKey();
}
public static int[] MyWhere(int[] nums, MyDel myDel)
{
List<int> list = new List<int>();
foreach (int n in nums)
{
//执行if时,会跳到"e % 2 == 0"语句,myDel(n)就相当于e => e % 2 == 0。
if (myDel(n))
{
list.Add(n);
}
}
return list.ToArray();
}
}
}
正常求水仙花数:
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text; namespace _06_Lambda水仙花数
{
class Program
{
public delegate List<int> MyDel(List<int> n);
static void Main(string[] args)
{
List<int> nums = new List<int>();
for (int i = ; i < ; i++)
{
nums.Add(i);
}
int[] nums2 = GetFlowers(nums.ToArray());
}
public static int[] GetFlowers(int[] nums)
{
List<int> list = new List<int>();
for (int i = ; i < nums.Length; i++)
{
//如123
int num = nums[i];
int n1 = num % ;
int n2 = num / % ;
int n3 = num / ;
int num2 = Convert.ToInt32(Math.Pow(Convert.ToDouble(n1), Convert.ToDouble()) + Math.Pow(Convert.ToDouble(n2), Convert.ToDouble()) + Math.Pow(Convert.ToDouble(n3), Convert.ToDouble()));
if (num == num2)
{
list.Add(num);
}
}
return list.ToArray();
}
}
}
Lambda表达式求水仙花,把上面的求偶数改了一下e=>{}大括号里面的内容就可以了,这么看似乎是简单复用了一些:
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text; namespace _00_Test
{
public delegate bool MyDel(int n);
class Program
{
static void Main(string[] args)
{
//生成100到1000的整数
List<int> nums = new List<int>();
for (int i = ; i < ; i++)
{
nums.Add(i);
}
//e=>{},大括号中,判断参数e是否符合水仙花条件,返回bool值。
int[] ns = MyWhere(nums.ToArray(), e =>
{
int n1 = e % ;
int n2 = e / % ;
int n3 = e / ;
int num2 = Convert.ToInt32(Math.Pow(Convert.ToDouble(n1), Convert.ToDouble()) + Math.Pow(Convert.ToDouble(n2), Convert.ToDouble()) + Math.Pow(Convert.ToDouble(n3), Convert.ToDouble()));
return num2 == e;
});
Console.ReadKey();
}
public static int[] MyWhere(int[] nums, MyDel myDel)
{
List<int> list = new List<int>();
foreach (int n in nums)
{
//执行if时,会跳到"e % 2 == 0"语句,myDel(n)就相当于e => {}。
if (myDel(n))
{
list.Add(n);
}
}
return list.ToArray();
}
}
}
C#学习笔记(29)——Linq的实现,Lambda求偶数和水仙花数的更多相关文章
- 【Unity 3D】学习笔记29:游戏的例子——简单的小制作地图
无论学习.只看不练是坏科学. 因此,要总结回想这怎么生产MMROPG小地图的游戏.于MMROPG游戏类,在游戏世界中行走时导致各地,通常在屏幕的右上角,将有一个区域,以显示当前的游戏场景微缩.在游戏世 ...
- [原创]java WEB学习笔记29:Cookie Demo 之自动登录
本博客为原创:综合 尚硅谷(http://www.atguigu.com)的系统教程(深表感谢)和 网络上的现有资源(博客,文档,图书等),资源的出处我会标明 本博客的目的:①总结自己的学习过程,相当 ...
- Entity Framework学习笔记(四)----Linq查询(1)
请注明转载地址:http://www.cnblogs.com/arhat 从本章开始,老魏就介绍一下Entity Framework使用Linq来查询数据,也就是Linq To Entity.其实在E ...
- Entity Framework学习笔记(五)----Linq查询(2)---贪婪加载
请注明转载地址:http://www.cnblogs.com/arhat 在上一章中,我们使用了Linq对Entity Framework进行了一个查询,但是通过学习我们却发现了懒加载给我来的性能上的 ...
- LinQ实战学习笔记(一) LINQ to (Objects, XML, SQL) 入门初步
LINQ对于笔者来说, 优美而浓缩的代码让人震惊. 研究LINQ就是在艺术化自己的代码. 之前只是走马观花学会了基本的语法, 但是经常在CSDN看到令人惊讶自叹不如的LINQ代码, 还是让人羡慕嫉妒恨 ...
- LinQ实战学习笔记(四) LINQ to Object, 常用查询操作符
这一篇介绍了下面的内容: 查询object数组 查询强类型数组 查询泛型字典 查询字符串 SelectMany 索引 Distinct操作符 排序 嵌套查询 分组 组连接 内连接 左外连接 交叉连接 ...
- Linux学习笔记29——IPC状态命令
一 IPC IPC是进程间通讯,在前面,我们相继学习了进程间通讯机制有信号量,内存共享,消息队列.状态命令(ipcs)和删除命令(ipcrm)提供了一种检查和清理IPC机制的方法. 二 状态命令 1 ...
- Kali学习笔记29:默认安装漏洞
文章的格式也许不是很好看,也没有什么合理的顺序 完全是想到什么写一些什么,但各个方面都涵盖到了 能耐下心看的朋友欢迎一起学习,大牛和杠精们请绕道 默认安装漏洞: 早期Windows默认自动开启很多服务 ...
- python学习笔记(十三)之lambda表达式
lambda表达式: 用法 lambda x : 2 * x + 1 其中:前面是参数,后面是返回值. >>> def ds(x): ... return 2 * x + 1 ... ...
随机推荐
- HDU 4324 Triangle LOVE (拓扑排序)
Triangle LOVE Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others)Tot ...
- 【Algorithm】快速排序
一. 算法描述 快速排序:快速排序采用分治法进行排序,首先是分割,选取数组中的任意一个元素value(默认选用第一个),将数组划分为两段,前一段小于value,后一段大于value:然后再分别对前半段 ...
- java反射之获取枚举对象
项目中导入大量枚举对象,用来定义常量.随着带来一个问题,就是每个枚举类都需要通过key来获取对应枚举的需求. public enum ExamType { CRAFT(1, "草稿" ...
- Linux中断 - 综述
一.前言 一个合格的linux驱动工程师需要对kernel中的中断子系统有深刻的理解,只有这样,在写具体driver的时候才能: 1.正确的使用linux kernel提供的的API,例如最著名的re ...
- 还没被玩坏的robobrowser(5)——Beautiful Soup的过滤器
背景 本节的知识还是属于Beautiful Soup的内容. Beautiful Soup的find和find_all方法非常强大,他们支持下面一些类型的过滤器. 字符串 最简单的过滤器是字符串.在搜 ...
- 项目记录25--unity-tolua框架 View02---BasePanel.lua
还在,还在. ... . 每天晚上找点时间写点点,多了也不想学到底是什么心理啊. 写完看电影去. 今天写两个算超完毕了BaseUI.lua,UIManager.lua(完好中这个) local Bas ...
- [转] spring的普通类中如何取session和request对像
在使用spring时,经常需要在普通类中获取session,request等对像.比如一些AOP拦截器类,在有使用struts2时,因为struts2有一个接口使用org.apache.struts2 ...
- 温故而知新 phpstudy 设置 nginx 代理
nginx.conif 找到 server 关键字配置 server { listen ; server_name localhost; #charset koi8-r; #access_log lo ...
- Java:多线程,CyclicBarrier同步器
1. 背景 CyclicBarrier类,它允许一组线程互相等待,直到到达某个公共屏障点 (common barrier point).在涉及一组固定大小的线程的程序中,这些线程必须不时地互相等待,此 ...
- 香蕉派 banana pi BPI-M3 八核开源硬件开发板
Banana PI BPI-M3 是一款8核高性能单板计算机,Banana PI BPI-M3是一款比树莓派 2 B更强悍的8核Android 5.1产品. Banana PI BPI-M3 兼 ...