免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
1234下一页
最近访问板块 发新帖
查看: 11526 | 回复: 35

如何编写一个邮件地址判断程序 [复制链接]

论坛徽章:
0
发表于 2010-06-04 13:16 |显示全部楼层
邮件地址是uuu@ddd.com格式的。

比如要求判断一个邮件地址是来自这些地方的:
sina.com
sohu.com
tom.com
gmail.com
21cn.com
msn.com
163.com
126.com
hotmail.com
yahoo.com
yahoo.cn
yahoo.com.cn
yahoo.com.tw
yahoo.tw
yahoo.com.mx
........
........
........
........
yahoo.fuck.fk

问如何编写程序简洁并高效

论坛徽章:
0
发表于 2010-06-04 13:22 |显示全部楼层
建一棵从右到左的字典树(trie tree),对每个输入匹配。

论坛徽章:
0
发表于 2010-06-05 12:58 |显示全部楼层
回复 2# 没本

太复杂了,无必要.建立TREE也花费时间的。
而这个查找整个程序期间也就是1,2次。

论坛徽章:
0
发表于 2010-06-05 15:34 |显示全部楼层
建树之后你做下持久化不就行了,就不用每次都重复建树的行为,无论你用什么办法,所有数据至少会遍历一次。之后的查找效率就看采用的数据结构和算法了。

论坛徽章:
0
发表于 2010-06-05 17:35 |显示全部楼层
把这些域名放进std::unordered_set(Hash容器,效率应该不错),然后查找就行了

论坛徽章:
0
发表于 2010-06-05 21:08 |显示全部楼层
回复 5# tyc611


那放入“容器“的过程是否也费时间?
代码也复杂?

论坛徽章:
0
发表于 2010-06-05 21:30 |显示全部楼层
回复  tyc611


那放入“容器“的过程是否也费时间?
代码也复杂?
思一克 发表于 2010-06-05 21:08


如果使用unordred_set的话,插入和查找的代码非常简单,一个函数调用而已
至于时间,不论是插入还是查找都是常量级,非常快了。当然,插入相对查找肯定慢些,但这儿插入应该是程序初始过过程中进行的,查找时间才是关键的

有一点,unordered_set是C++ TR1库引入的,可能有些编译器还不支持,但应该有一些功能类似的类,可能名字不一样(比如,hash_set)

论坛徽章:
0
发表于 2010-06-05 21:35 |显示全部楼层
哈希表的字符串哈希是32bits的,有碰撞的可能性,不过机会不大,我这里也常用。

论坛徽章:
154
2022北京冬奥会纪念版徽章
日期:2015-08-07 17:10:5720周年集字徽章-年
日期:2022-10-26 16:44:2015-16赛季CBA联赛之深圳
日期:2022-11-02 14:02:4515-16赛季CBA联赛之八一
日期:2022-11-28 12:07:4820周年集字徽章-20	
日期:2023-07-19 08:49:4515-16赛季CBA联赛之八一
日期:2023-11-04 19:23:5115-16赛季CBA联赛之广夏
日期:2023-12-13 18:09:34
发表于 2010-06-05 21:41 |显示全部楼层
nice

论坛徽章:
0
发表于 2010-06-06 14:09 |显示全部楼层
那比如,要写一个程序,判断一个域名是否在那列表里面(。。。地方比如还有50个yahoo),  列表里一共有60多个域名。

如何写能使得查找一两次速度最快?代码最短?

int is_in_domain_list(char *domain)
{



}
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP