找答案的高端用户(找答案钻石及双钻级别的用户)将尽可能从此问题下的所有回
答中,为您推荐最佳答案。届时您可以根据推荐数采纳答案。
如果自提问时间起7天内您仍无法选出最佳答案,您可以选择“无满意答案”关闭此问题。
问题
取消精华
首页精华问答
取消推荐
高端用户推荐
申请置评
已申请置评
修改
修改标签
添加标签
官方认证
取消官方认证
修改标签
添加标签
转移分类
删除
{{itemCategory}}
收藏({{answerDetail.Q_FavoriteCounts}})
手机扫码追踪该问题,
觉得实用,立即去分享!
点击复制链接
专家建议
取消最佳答案
修改
如果这个100个双字无序排列,没有除了依次循环比较没有好的办法。
如果这个100个双字有序排列,可以采用二分法快速进行快速比较:
//假设100个数据放在DataList Array[1..100] 数组,按照从小到大排列
//假设要比较的数据DataFind
#Found := 0; //没找到0,找到数组下标
#iMin := 1;
#iMax := 100;
WHILE 1 DO
#iCp := (#iMin + #iMax)/2; //对比较区间二分
IF DataFind = DataList[#iCp] THEN //比中则结束
#Found := #iCp;
EXIT;
ELSIF DataFind < DataList[#iCp] THEN //继续比较前半部分
#iMax := #iCp - 1;
ELSE //继续比较后半部分
#iMin := #iCp + 1;
END_IF;
IF #iMax < #iMin THEN //没有了
EXIT;
END_IF;
END_WHILE;
点赞({{answerDetail.Q_Positive}})
评论
评论
精探推荐
等您来回答
换一换
{{item.CoinValue}}西币
{{item.VisitNum}}人想问
本版相关问题
换一换
专家置评
首次回答问题,获得
双倍西币积分!
立即成为技术知识分享的一员!
欢迎您访问支持中心!
丰富的视频,全方位的文档,大量的网友交流精华……
为了更好的完善这些内容,我们诚邀您在浏览结束后,花20秒左右的时间,完成一个用户在线调查!
感谢您的支持!

西门子商城