- 1、本文档内容版权归属内容提供方,所产生的收益全部归内容提供方所有。如果您对本文有版权争议,可选择认领,认领后既往收益都归您。。
- 2、本文档由用户上传,本站不保证质量和数量令人满意,可能有诸多瑕疵,付费之前,请仔细先通过免费阅读内容等途径辨别内容交易风险。如存在严重挂羊头卖狗肉之情形,可联系本站下载客服投诉处理。
- 3、文档侵权举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
云南开放大学算法设计与分析第九章随机算法
习题
1.设有一个文件含有x个记录。
试设计一个算法随机抽取该文件中y个记录。
如果事先不知道文件中记录个数,应如何随机抽取其中的y个记录
参考答案:
已知记录总数x时:
使用蓄水池抽样(ReservoirSampling)的变种(当x已知时更简单):
若y=x,直接返回所有记录。
否则:
将前y个记录直接放入结果集。
对第i个记录(i从y+1到x),以概率y/i随机替换结果集中的某一个记录。
最终结果集中的y个记录即为随机样本。
未知记录总数x时:
使用蓄水池抽样算法(AlgorithmR):
初始化:将前y个记录存入结果集。
对第i
原创力文档


文档评论(0)