mud_sanc 板


LINE

※ 引述《cloderw (漫云端)》之铭言: : sort_array 本身是不断地带入阵列中的两个元素做比对 : 因此若阵列元素有 N 个,sort_names 就会被执行 N x N-1 次(不跟自己比较) : 也因此阵列元素数量愈多,sort_array 效能就会大符下降 : 因此在撰写 sort_names 等比较函式时,必须尽量的最佳化 : 单就排序玩家名称的部份,若想进一步提高效率 : 可以先用 map() 这个 efun 将所有玩家的名称一次 query 出来 : 建立一个存满所有玩家名称的字串阵列 allnames : string *allnames = map(users(), (: $1->query("name") :)) 圣殿比较少用到这个(我也没用过:p),上面的东西类似底下.. mixed usr=users(),allnames=({}); object ppl; foreach(ppl in usr) allnames+=({ ppl->query("name") }); 或者用这个... mixed allnames=users(); int i,j; object ppl; for(i=0,j=sizeof(allnames);i<j;i++) { ppl=allnames[i]; allnames[i]=ppl->query("name"); } clode 提供的部份只用一行解决,简洁很多^^ mixed *map_array( mixed *arr, string fun, object ob, mixed extra, ... ); (在上面的例子下使用 map = 使用 map_array) 如果看不懂上面就跟 sort_array 对照看.. mixed *sort_array( mixed *arr, string fun, object ob ); 类推一下.. (不过 (: :) 这个我之前怎麽看都看不懂哩,哈哈...) : 然後再将 allnames 丢进 sort_array 排序 : 如此就可以马上减少 sort_names 中 N x N-1 次的 ob->query() 执行 : 假设 N = 100, 每次执行 sort_names 所损耗的执行时间为 1ms : 这样做马上就可以减少 100x(100-1)*1ms = 9900ms = 9.9sec : 可以大幅提升效能(当然 sort_names 应该不会花到 1ms 那麽夸张啦..XD) : 另外单纯比对字串的话 : 可以直接使用 strcmp() 这个 efun 来取代自己写的 sort_names 函式 : 但 strcmp 只能单纯依照固定的字母顺序排序,缺乏变化 : 需要特殊条件的排序就还是得自己撰写 sort_names 函式 : 像是名称中包括色码等隐藏码,就会需要另外进行过滤处理 : 仅供参考... 呵,之前太懒没有先确定 mud 有没有 strcmp 函数,才想说自己写, sort_names 经改写後如下.. int sort_names(string a1,string a2) { return strcmp(a1,a2); } Laechan --



※ 发信站: 批踢踢实业坊(ptt.cc)
◆ From: 118.170.110.15 ※ 编辑: laechan 来自: 218.162.98.7 (02/11 07:52)







like.gif 您可能会有兴趣的文章
icon.png[问题/行为] 猫晚上进房间会不会有憋尿问题
icon.pngRe: [闲聊] 选了错误的女孩成为魔法少女 XDDDDDDDDDD
icon.png[正妹] 瑞典 一张
icon.png[心得] EMS高领长版毛衣.墨小楼MC1002
icon.png[分享] 丹龙隔热纸GE55+33+22
icon.png[问题] 清洗洗衣机
icon.png[寻物] 窗台下的空间
icon.png[闲聊] 双极の女神1 木魔爵
icon.png[售车] 新竹 1997 march 1297cc 白色 四门
icon.png[讨论] 能从照片感受到摄影者心情吗
icon.png[狂贺] 贺贺贺贺 贺!岛村卯月!总选举NO.1
icon.png[难过] 羡慕白皮肤的女生
icon.png阅读文章
icon.png[黑特]
icon.png[问题] SBK S1安装於安全帽位置
icon.png[分享] 旧woo100绝版开箱!!
icon.pngRe: [无言] 关於小包卫生纸
icon.png[开箱] E5-2683V3 RX480Strix 快睿C1 简单测试
icon.png[心得] 苍の海贼龙 地狱 执行者16PT
icon.png[售车] 1999年Virage iO 1.8EXi
icon.png[心得] 挑战33 LV10 狮子座pt solo
icon.png[闲聊] 手把手教你不被桶之新手主购教学
icon.png[分享] Civic Type R 量产版官方照无预警流出
icon.png[售车] Golf 4 2.0 银色 自排
icon.png[出售] Graco提篮汽座(有底座)2000元诚可议
icon.png[问题] 请问补牙材质掉了还能再补吗?(台中半年内
icon.png[问题] 44th 单曲 生写竟然都给重复的啊啊!
icon.png[心得] 华南红卡/icash 核卡
icon.png[问题] 拔牙矫正这样正常吗
icon.png[赠送] 老莫高业 初业 102年版
icon.png[情报] 三大行动支付 本季掀战火
icon.png[宝宝] 博客来Amos水蜡笔5/1特价五折
icon.pngRe: [心得] 新鲜人一些面试分享
icon.png[心得] 苍の海贼龙 地狱 麒麟25PT
icon.pngRe: [闲聊] (君の名は。雷慎入) 君名二创漫画翻译
icon.pngRe: [闲聊] OGN中场影片:失踪人口局 (英文字幕)
icon.png[问题] 台湾大哥大4G讯号差
icon.png[出售] [全国]全新千寻侘草LED灯, 水草

请输入看板名称,例如:e-shopping站内搜寻

TOP