登录名:  密码:  验证码: 4889
设为首页 收藏本站 联系站长
2008年7月5日
农历戊子年(鼠)
六月初三
 首页 | 最新上传 | 新闻 | 购物商场 | 招聘求职 | HTML学习 | java学习 | IT新闻 | 黑客技术 | 域名和空间 | 流量统计 | 故事小说
 GIF动画制作 | 图片素材 | 源码下载 | 书籍下载 | 视频资料 | ASP | 数据库 | PHP | 基本电脑知识 | 迅雷资源 | 兼职 | 组网工程
 英语学习 | FLASH专区 | ASP.NET | VB | 综合资源网 | 驱动下载 | 游戏下载 | 网站模板网页美工 | 韩文学习 | 论坛
 特别推荐:漂亮网站网址  图片素材
  我要查找:  
欢迎您来这里。每天学一点,每天进步一点!
Google
 当前位置:首页 >> ASP.NET  >> ASP.NET
ASP.NET从字符串中查找字符出现次数的方法和性能对比
来源:http://whx.tzgt.gov.cn  发表日期:2008年5月10日 作者: 

 编辑:admin 级别: 司令 浏览次数:34
】    
今天在一场“特殊的讨论”中引入了一个问题,如何在C#求出字符串中某字符的出现次数,比如求“ADSFGEHERGASDF”中“A”出现的次数。首先想到的方法当然是从头遍历字符串并统计:
程序代码 程序代码

c1 = 0;
for (int i = 0; i < str.Length; i++)
{
    if (str[i] == 'A')
    {
        c1++;
    }
}

第二种方法也很容易想到,将字符串中所有要查找的字符去除,然后比较去除前后的字符串长度即可。这种方法遭到了某人的鄙视,据说性能很差而且多占空间。
程序代码 程序代码
c2 = str.Length - str.Replace("A", String.Empty).Length;


接下来某人又提出了第三种方法,是用要查找的字符为分隔符,将原字符串分隔为多个子串,然后求子串的数目即可。在C#中这是一个写起来很短的方法:
程序代码 程序代码
c3 = str.Split(new char[] { 'A' }).Length - 1;


我们从原理可以推断出三者性能的顺序,但究竟差距是多少呢,还是要动手试验一下。这是非常经典的测试代码:

程序代码 程序代码

string str = "SADTHDGSAFSDGTGHRDGSADFADDRHDFSGASDAA";

Stopwatch sw = new Stopwatch();

long t;
int c = 0;
GC.Collect();
Application.DoEvents();

sw.Start();

for (int i = 0; i < 100000; i++)
{
    c = 三种算法
}

sw.Stop();

t = sw.ElapsedMilliseconds;

首先我们确保正确性,经测试三种方法都能正确处理多种情况,包括首尾、连续出现、不出现或串长度为0等,我所取的字符串是一个很普通的串。编译为Release版,预运行10次后获得以下结果:

遍历统计:13毫秒
替换后比较长度:112毫秒
断开字符串后计数:233毫秒

这里已经体现出差异,遍历统计比替换后比较要快10倍,断开字符串又要慢一些。接下来我又做了如下两个测试:

1、不改变字符串的长度,增加或减少要查找字符串的个数。
2、不改变要查找字符出现的频率,但增长字符串的长度。

结果发现,三种方法都随字符串长度增加线性变慢,而后两种方法还随要查找的字符增加而变慢。断开字符串的方法还受要查找字符串分布情况的影响。

研究Replace函数和Split函数的实现可以彻底解决这个问题。不过我没有心情细细研究了,我还是决定选用第二种方法——替换后比较长度。虽然其速度比第一种方法慢,但易于改写为求长度不为1的子串出现次数的方法。第一种方法若改为求长度大于1的字串就要考虑很多因素(尽管不一定真的很麻烦),我懒得想了,呵呵。
(编辑:网站学习网)
Google
 ·上一篇文章: ASP.NET教程:抽象类和接口的比较
 ·下一篇文章: 用C语言编写二分法解方程程序
 该篇文章的评论
 暂无相关评论
 姓名:  邮箱:
 内容:
                
 相关文章
 · Microsoft Data Access
 · 请问Microsoft Data Acc
 · 在XP下配置ASP.net的运行
 · resx是什么文件
 · asp.net C#连接SQL
 · asp.net调用Console程序
 · Visual studio&nbs
 · 怎样安装和使用Visual&n
 · resx是什么文件?
 · Asp.net简单会员管理系统
 · 请问: <body&n
 · 关于如何得到新增记录的
 最新上传文章
 · 对宁波市鄞州区溪下村委
 · dlink无线路由设置
 · 无线路由器的无线加密设
 · 18岁黑客开博卖病毒&nbs
 · D-Link 无线路由器
 · 无线路由器密钥破解!
 · 把excel表格导入到acces
 · 金超群版包青天共有哪几
 · 一个黑客眼里的隐私(下
 · 网页与网站的基本知识
 · FrontPage建立超级连接书

服务说明 | 关于网站 | 联系我们 | 友情链接
网站学习网欢迎您!
http://www.studywebgood.com
浙ICP备07030755号 
联系邮箱:shuizhilang@126.com 如本网站侵犯了您的版权,请马上通知我.