十六、C# 常用集合类及构建自定义集合(使用迭代器)
public class BinaryTree<T> : IEnumerable<T>
{
public BinaryTree(T value)
{ }
public IEnumerator<T> GetEnumerator()
{
}
public T Value
{
get { return _value; }
set { _value = value; }
}
private T _value;
}
public struct Pair<T>
{
private T _first;
private T _second;
public T First
{
get { return _first; }
set { _first = value; }
}
public T Second
{
get { return _second; }
set { _second = value; }
}
public Pair(T first,T second)
{
_first = first;
_second = second;
}
}
class Program
{
static void Main(string[] args)
{
CSharpPrimitiveTypes primitives = new CSharpPrimitiveTypes();
foreach (string primitive in primitives)
{
Console.WriteLine(primitive);
} Console.ReadLine(); } } public class CSharpPrimitiveTypes : IEnumerable<string>
{
public IEnumerator<string> GetEnumerator()
{
yield return "object";
yield return "byte";
yield return "uint";
yield return "ulong";
yield return "float";
yield return "char";
yield return "bool";
yield return "string";
} //因为System.Collections.Generic.IEnumerable<T>继承
//System.Collections.IEnumerable这个接口,所以也需要实现
System.Collections.IEnumerator System.Collections.IEnumerable.GetEnumerator()
{
return GetEnumerator();
}
}
class Program
{
static void Main(string[] args)
{
Pair<string> fullname = new Pair<string>("xxm", "yyp");
foreach (string name in fullname)
{
Console.WriteLine(name);
} Console.ReadLine(); } } public struct Pair<T> : IEnumerable<T>
{
private T _first;
private T _second;
public T First
{
get { return _first; }
set { _first = value; }
}
public T Second
{
get { return _second; }
set { _second = value; }
}
public Pair(T first, T second)
{
_first = first;
_second = second;
}
#region IEnumerable<T>
public IEnumerator<T> GetEnumerator()
{
yield return First;
yield return Second;
}
#endregion
#region IEnumerable Members
System.Collections.IEnumerator System.Collections.IEnumerable.GetEnumerator()
{
return GetEnumerator();
}
#endregion
}
class Program
{
static void Main(string[] args)
{
BinaryTree<string> jfkFamilyTree = new BinaryTree<string>("root");//根节点 jfkFamilyTree.Subitems = new Pair<BinaryTree<string>>(//左右树的根节点
new BinaryTree<string>("root-left"),
new BinaryTree<string>("root-right")
);
jfkFamilyTree.Subitems.First.Subitems = new Pair<BinaryTree<string>>(//左子树的左右子树的根节点
new BinaryTree<string>("root-left-left"),
new BinaryTree<string>("root-left-right")
);
jfkFamilyTree.Subitems.Second.Subitems = new Pair<BinaryTree<string>>(//右子树的左右子树的根节点
new BinaryTree<string>("root-righ-left"),
new BinaryTree<string>("root-righ-right")
); //遍历二叉树
foreach (string node in jfkFamilyTree)
{
Console.WriteLine(node);
} Console.ReadLine(); } } //二叉树(根节点,左右子树)
public class BinaryTree<T> : IEnumerable<T>
{ public BinaryTree(T value)
{
_value = value;
} private T _value;//根节点
public T Value
{
get { return _value; }
set { _value = value; }
}
private Pair<BinaryTree<T>> _subitems;//子树,总共两个,左子树和右子数
public Pair<BinaryTree<T>> Subitems//子树元素,每一项都是一个树
{
get { return _subitems; }
set
{
IComparable first;
first = (IComparable)value.First.Value;
if (first.CompareTo(value.Second.Value) < )
{
//first is less than second.
//在这可以做处理,比如交换,或者报错提示
//不过值类型赋值不会成功,需要使用其它方式,如换成类而不是struct
}
else
{
//first is not less than second.
}
_subitems = value;
}
}
public IEnumerator<T> GetEnumerator()
{
yield return Value;//返回根节点 foreach (BinaryTree<T> tree in Subitems)//遍历所有子树,从左向右遍历
{
if (tree != null)
{
foreach (T item in tree)//遍历子树当中的所有节点,会引起BinaryTree<T>中的GetEnumerator()递归调用
{
yield return item;
} }
} }
#region IEnumerable Members
System.Collections.IEnumerator System.Collections.IEnumerable.GetEnumerator()
{
return GetEnumerator();
}
#endregion } //子树类(左右子树)
public struct Pair<T> : IEnumerable<T>
{
private T _first;//左子树
private T _second;//右子树
public T First
{
get { return _first; }
set { _first = value; }
}
public T Second
{
get { return _second; }
set { _second = value; }
} public Pair(T first, T second)
{
_first = first;
_second = second;
}
#region IEnumerable<T>
public IEnumerator<T> GetEnumerator()
{
yield return First;
yield return Second;
}
#endregion #region IEnumerable Members
System.Collections.IEnumerator System.Collections.IEnumerable.GetEnumerator()
{
return GetEnumerator();
}
#endregion
}
Pair<string> game = new Pair<string>("first","second");
foreach (string name in game.GetReverseEnumerator())
{
Console.WriteLine(name);
}
public struct Pair<T> : IEnumerable<T>
{
...
public IEnumerable<T> GetReverseEnumerator()
{
yield return Second;
yield return First;
}
}
十六、C# 常用集合类及构建自定义集合(使用迭代器)的更多相关文章
- (转)JAVA 十六个常用工具类
一. org.apache.commons.io.IOUtils closeQuietly 关闭一个IO流.socket.或者selector且不抛出异常.通常放在finally块 toString ...
- 《C#本质论》读书笔记(16)构建自定义集合
16.1 更多集合接口 集合类(这里指IEnumerable层次结构)实现的接口层次结构 16.1.1 IList<T>与IDictionary<TKey,TValue> 字典 ...
- Python学习(三十六)—— Cookie、Session和自定义分页
一.Django中操作Cookie 获取Cookie request.COOKIES['key'] request.get_signed_cookie(key, default=RAISE_ERROR ...
- 大数据笔记(十六)——Hive的客户端及自定义函数
一.Hive的Java客户端 JDBC工具类:JDBCUtils.java package demo.jdbc; import java.sql.DriverManager; import java. ...
- MFC编程入门之二十六(常用控件:滚动条控件ScrollBar)
回顾上一节,讲的是组合框控件Combo Box的使用.本节详解滚动条控件Scroll Bar的相关内容. 滚动条控件简介 滚动条大家也很熟悉了,Windows窗口中很多都有滚动条.前面讲的列表框和组合 ...
- VS2010/MFC编程入门之二十六(常用控件:滚动条控件Scroll Bar)
回顾上一节,鸡啄米讲的是组合框控件Combo Box的使用.本节详解滚动条控件Scroll Bar的相关内容. 滚动条控件简介 滚动条大家也很熟悉了,Windows窗口中很多都有滚动条.前面讲的列表框 ...
- 测开之路三十六:常用的css选择器
在static下新建一个css,并写入内容 /*标签选择器,label标签的颜色为红色*/label {color: red;} /*.代表类选择器,绿色*/.test {color: green;} ...
- Gradle 1.12 翻译——第十六章. 使用文件
有关其它已翻译的章节请关注Github上的项目:https://github.com/msdx/gradledoc/tree/1.12,或訪问:http://gradledoc.qiniudn.com ...
- JAVA之旅(二十六)——装饰设计模式,继承和装饰的区别,LineNumberReader,自定义LineNumberReader,字节流读取操作,I/O复制图片
JAVA之旅(二十六)--装饰设计模式,继承和装饰的区别,LineNumberReader,自定义LineNumberReader,字节流读取操作,I/O复制图片 一.装饰设计模式 其实我们自定义re ...
随机推荐
- 分布式文件系统MFS(moosefs)实现存储共享(一)
分布式文件系统MFS(moosefs)实现存储共享 作者:田逸(sery@163.com) from:[url]http://net.it168.com/a2009/0403/270/00000027 ...
- bzoj3083 3306
又见bzoj的语言歧视,囧……bzoj3083过了本地的数据在上面出现各种奇葩的TLE835083 phile 3083 Time_Limit_Exceed 17092 kb 4872 ms Pasc ...
- Maven学习(3) - Maven和Eclipse集成和构建多模块Maven项目
最近在工作中越来越经常的用到了Maven作为项目管理和Jar包管理和构建的工具,感觉Maven的确是很好用的.而且要将Maven的功能最大发挥出来,多模块是一个很好的集成例子. 一个Maven项目包括 ...
- 分布式文件系统FastDFS安装与配置(单机)
安装包如下:fastdfs-nginx-module_v1.16.tar.gzFastDFS_v5.05.tar.gzlibfastcommon-master.zipnginx-1.8.0.tar.g ...
- 清除nginx静态资源缓存
之前写过一篇如何配置nginx缓存及手动清除缓存的文章: http://www.cnblogs.com/Eivll0m/p/4921829.html 但如果有大量缓存需要清理,手动一条条清理就比较慢了 ...
- 如何以非 root 用户将应用绑定到 80 端口-ssh 篇 » 社区 » Ruby China
如何以非 root 用户将应用绑定到 80 端口-ssh 篇 » 社区 » Ruby China 如何以非 root 用户将应用绑定到 80 端口-ssh 篇
- ERROR: The node /hbase is not in ZooKeeper. It should have been written by the master. Check the value configured in 'zookeeper.znode.parent'. There could be a mismatch with the one configured in the
hbase shell下list命令出错. [hadoop@djt002 hbase]$ hbase shell 2016-07-20 19:37:12,522 INFO [main] Confi ...
- 53个要点提高php效率
用单引号代替双引号来包含字符串,这样做会更快一些.因为PHP会在双引号包围的字符串中搜寻变量,单引号则不会,注意:只有echo能这么做,它是一种可以把多个字符串当作参数的“函数”(译注:PHP手册中说 ...
- 【题解】A-B
[问题描述]出题是一件痛苦的事情!题目看多了也有审美疲劳,于是我舍弃了大家所熟悉的 A+B Problem,改用 A-B 了哈哈!好吧,题目是这样的:给出一串数以及一个数字 C,要求计算出所有 A-B ...
- winform 获取文件夹的名称 分类: WinForm 2014-08-04 15:50 242人阅读 评论(0) 收藏
目的:获取项目路径下所有文件夹的名称,并绑定到Combobox控件下: 显示要求:此文件夹名称和他的子文件名称的集合: Combobox控件名称:cmbFile 图示: 代码实现: //项目路径 st ...