C#集合之Hashtable
Hashtable是一个键值对集合,其泛型版本是Dictionary<K, V>,下面说下常用的一些方法;
1.Add(),向Hashtable添加元素,需要注意的是因为它是键值对集合,所以要同时添加一个键和一个值,且键不能重复。
2.ContainsKey(key)方法,是查询是否包含某个键,其Contains()方法最终也是调用这个方法实现的。
3.ContainsValue(value)方法,是查询是否包含某个值。
4.hash[“key”],根据键获取某个值。hash[“key”]=“修改”,根据键修改对应的值。
5.Remove(“key”);根据键删除对应的值。
需要注意的是,以上3个方法,其泛型版本Dictionary<K, V>也是一样的。
Keys属性,是Hashtable的键集合。Values属性,是Hashtable的值集合;可以通过foreach遍历它的键集合和值集合。
如果要同时得到Hashtable中的键集合和值集合,在使用foreach遍历时,请将var关键字替换为DictionaryEntry,这样就能同时拿到键和值了。
而对于Dictionary<K, V>要同时得到键集合和值集合,在使用foreach遍历时,请将var关键字替换为KeyValuePair<k,v>。
键值对集合,如果得到键,可以使用 集合名[键名]这样的索引方式获取对应的值。因为键值对集合不提供下标来访问,故这类集合不能通过for循环来遍历。
下面看几个例子程序,以便更好理解其实际应用:
1.将int数组中的奇数放到一个新的int数组中返回
int[] iArray = new int[] { 2, 7, 8, 3, 22, 9, 5, 11, 14, 18, 21 };
ArrayList aLst = new ArrayList();
for (int i = 0; i < iArray.Length; i++)
{
if (iArray[i] % 2 != 0)
{
aLst.Add(iArray[i]);
}
}
object[] obj = aLst.ToArray();
foreach (var item in obj)
{
Console.WriteLine(item);
}
Console.ReadKey();
2.从一个整数的List<int>中取出最大数(找最大值)(最简单是调用List集合的max方法)
private static int GetMax(List<int> iList)
{
int iMax = iList[];
for (int i = ; i < iList.Count; i++)
{
if (iList[i]>iMax)
{
iMax = iList[i];
}
}
return iMax;
}
3.把123转换为:壹贰叁。
/// <summary>
/// 数字转换成大写汉字
/// </summary>
/// <param name="msg"></param>
/// <returns></returns>
private static string ConvertInt(string msg)
{
string s = "0零 1壹 2贰 3叁 4肆 5伍 6陆 7柒 8扒 9玖";
Dictionary<char, char> dic = new Dictionary<char, char>(); string[] strArray = s.Split(' ');
for (int i = ; i < strArray.Length; i++)
{
dic.Add(strArray[i][], strArray[i][]);
} StringBuilder sb = new StringBuilder(); for (int i = ; i < msg.Length; i++)
{
if (dic.ContainsKey(msg[i]))
{
sb.Append(dic[msg[i]]);
}
else
{
sb.Append(msg[i]);
}
}
return sb.ToString();
}
4.计算字符串中每种字母出现的次数(面试题)。 “Welcome ,to Chinaworld”
Dictionary<char, int> dic = new Dictionary<char, int>();
for (int i = ; i < msg.Length; i++)
{
if (!dic.ContainsKey(msg[i]))
{
dic.Add(msg[i], );
}
else
{
dic[msg[i]] = dic[msg[i]] + ;
}
}
foreach (KeyValuePair<char, int> item in dic)
{
Console.WriteLine("字符<{0}>在文本中出现了{1}次", item.Key, item.Value);
}
延伸,如果是要统计一段中文中,某个词组呢?
string msg = "患者:“大夫,我咳嗽得很重。” 大夫:“你多大年记?” 患者:“七十五岁。” 大夫:“二十岁咳嗽吗”患者:“不咳嗽。” 大夫:“四十岁时咳嗽吗?” 患者:“也不咳嗽。” 大夫:“那现在不咳嗽,还要等到什么时咳嗽?”";
string key = "咳嗽";
int iIndex = msg.IndexOf(key, );
if (iIndex!=-)
{
Console.WriteLine("字符{0}第1次出现的位置是:{1}", key, iIndex);
} int iCount = ;
while (iIndex != -)
{
iIndex = msg.IndexOf(key, iIndex + key.Length);
if (iIndex != -)
{
iCount++;
Console.WriteLine("字符{0}第{1}次出现的位置是:{2}", key, iCount, iIndex);
}
else
{
break;
}
}
5.编写一个函数进行日期转换,将输入的中文日期转换为阿拉伯数字日期,比如:二零一二年十二月月二十一日要转换为2012-12-21
private static string ConvertDate(string strDate)
{
Dictionary<char, char> dic = new Dictionary<char, char>();
string s = "零0 一1 二2 三3 四4 五5 六6 七7 八8 九9";
string[] strArray = s.Split(' ');
for (int i = ; i < strArray.Length; i++)
{
dic.Add(strArray[i][], strArray[i][]);
} StringBuilder sb = new StringBuilder();
for (int j = ; j < strDate.Length; j++)
{
if (dic.ContainsKey(strDate[j]))
{
sb.Append(dic[strDate[j]]);
}
else
{
if (strDate[j]=='十')
{
//1.十 10 10
//2.二十 20 0
//3.十二 12 1
//4.二十二 22 不翻译 if (!dic.ContainsKey(strDate[j - ]) && !dic.ContainsKey(strDate[j + ]))
{
sb.Append("");
}
else if (dic.ContainsKey(strDate[j - ]) && !dic.ContainsKey(strDate[j + ]))
{
sb.Append("");
}
else if (!dic.ContainsKey(strDate[j - ]) && dic.ContainsKey(strDate[j + ]))
{
sb.Append("");
}
else if (dic.ContainsKey(strDate[j - ]) && dic.ContainsKey(strDate[j + ]))
{ }
}
else
{
sb.Append(strDate[j]);
}
}
}
string n = sb.ToString().Replace('年','-');
n = n.Replace('月', '-');
return n.Replace('日',' ');
}
上面代码中的中文注释还对不同情况做了判断。
关于集合,先就说这么多,写出来算是给自己的总结,留作他日复习用。如果各路大神有补充,请跟我联系,共同进步啊!
C#集合之Hashtable的更多相关文章
- C#基础课程之五集合(HashTable,Dictionary)
HashTable例子: #region HashTable #region Add Hashtable hashTable = new Hashtable(); Hashtable hashTabl ...
- 从内部剖析C#集合之HashTable
计划写几篇文章专门介绍HashTable,Dictionary,HashSet,SortedList,List 等集合对象,从内部剖析原理,以便在实际应用中有针对性的选择使用. 这篇文章先介绍Hash ...
- 从内部剖析C# 集合之---- HashTable
这是我在博客园的第一篇文章,写的不好或有错误的地方,望各位大牛指出,不甚感激. 计划写几篇文章专门介绍HashTable,Dictionary,HashSet,SortedList,List 等集合对 ...
- Stack集合、queue集合、hashtable集合
1.栈:Stack,先进后出,一个一个赋值,一个一个取值,按顺序. .count 取集合内元素的个数 .push() 将元素一个一个推入集合中//stack集合存入 ...
- Java集合之Hashtable
和HashMap一样,Hashtable也是一个散列表,存储的内容也是键值对key-value映射.它继承了Dictionary,并实现了Map.Cloneable.io.Serializable接口 ...
- Map集合、HashMap集合、LinkedHashMap集合、Hashtable集合、Collections工具类和模拟斗地主洗牌和发牌
1.Map集合概述和特点 * A:Map接口概述 * 查看API可以知道: * 将键映射到值的对象 * 一个映射不能包含重复的键 * 每个键最多 ...
- Java集合——HashMap,HashTable,ConcurrentHashMap区别
Map:“键值”对映射的抽象接口.该映射不包括重复的键,一个键对应一个值. SortedMap:有序的键值对接口,继承Map接口. NavigableMap:继承SortedMap,具有了针对给定搜索 ...
- C#中的集合(HashTable与Array类)【转】
一.Array类 1.Array类的属性 序号 属性 & 描述 1 IsFixedSize 获取一个值,该值指示数组是否带有固定大小. 2 IsReadOnly 获取一个值,该值指示数组是否只 ...
- 集合之HashTable
在java中与有两个类都提供了一个多种用途的hashTable机制,他们都可以将可以key和value结合起来构成键值对通过put(key,value)方法保存起来,然后通过get(key)方法获取相 ...
随机推荐
- IE比Chrome强的一个地方
今天在开发时,调试一个功能.死活显示和同事不一样,他是测试过正常的,我的Chrome显示死活不对. 最后要重新部署了,才想起会不会是缓存的问题.清除Chrome缓存,再一试,一切正常. IE有一个功能 ...
- React-native 中的触摸响应功能
我们在做APP的时候,与桌面应用系统不同的是触摸响应. web页面对触摸响应的支持和原生的APP有着很大的差异. 基本用法 componentWillMount: function() { this. ...
- 【STL学习】智能指针之shared_ptr
前面已经学习过auto_ptr,这里补充另外一种智能指针,比auto_ptr要更强力更通用的shared_ptr. shared_ptr 简介及使用选择 几乎所有的程序都需要某种形式的引用计数智能指 ...
- 看文章《EAI和SOA的比较》有感(1)
<EAI和SOA的比较>http://www.cnblogs.com/asdling/archive/2007/11/26/973100.html这篇文章写的很全面,至少自己这么认为,也解 ...
- [React Native] Complete the Notes view
In this final React Native lesson of the series we will finalize the Notes view component and squash ...
- MyEclipse设置默认的目光格式
首先,选择菜单 windows-->preference Java-->Code Style-->Code Templates code-->new Java files 然后 ...
- springMVC整合xStream
一. 简单介绍: xStream能够轻易的将Java对象转换成xml.JSON.本篇博客将使用springMVC整合利用xStream转换xml. 关于xStream使用的博文:http://blog ...
- 几种sap增强的查找方法
***方法一**************************************** 通过SE30,运行TCODE后,点Evaluate后,查看运行时间分析评估:命中清单. 找以“exit”开 ...
- Java 之 调用.Net的 WebService 整理
最近做一个 java 调用 .net 服务的项目,其中 .net做了一个WebService,需要java来调用. 最开始.net的Service代码如下: using System; using S ...
- 观锁与悲观锁(Hibernate)
乐观锁与悲观锁 文章转自网上好像是玉米田的,忘记了 锁( locking ) 业务逻辑的实现过程中,往往需要保证数据访问的排他性.如在金融系统的日终结算 处理中,我们希望针对某个 cut-off 时间 ...