| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1285 人关注过本帖
标题:C++ shuffle算法问题
只看楼主 加入收藏
幻楚
Rank: 1
等 级:新手上路
帖 子:59
专家分:0
注 册:2013-5-15
结帖率:0
收藏
已结贴  问题点数:10 回复次数:6 
C++ shuffle算法问题
随机序列生成算法,我使用了 random_shuffle 来打乱有序序列,但是每次生成的 序列都是一样的,我也设置了系统时间为种子,但是还是固定序列,我想问问这是怎么回事?求大神们帮忙看看,解释一下。

 代码如下:
#include <iostream>
#include <vector>

int main()
{
    std::srand((unsigned)time(0));  // 这句话没有起作用,我试过用一个固定值或者注释掉这句话,生成的序列都是一样的
    std::cout << "system time : " << time(0) << std::endl;
   
    std::vector<int> v;
    std::ostream_iterator<int> out_iter(std::cout, " ");

    for(int i=0; i<10; ++i)
    {
        v.push_back(i);
    }
   
    std::random_shuffle(v.begin(), v.end());
   
    copy(v.begin(), v.end(), out_iter);
   
    std::cout << "\n";
    return 0;
}

运行结果:

第一次运行:
system time : 1487231414
6 0 3 5 7 8 4 1 2 9
Program ended with exit code: 0

第二次运行:
system time : 1487231496
6 0 3 5 7 8 4 1 2 9
Program ended with exit code: 0

搜索更多相关主题的帖子: shuffle include system 
2017-02-16 15:53
幻楚
Rank: 1
等 级:新手上路
帖 子:59
专家分:0
注 册:2013-5-15
收藏
得分:0 
自己先顶一下

C plus plus
2017-02-16 15:53
幻楚
Rank: 1
等 级:新手上路
帖 子:59
专家分:0
注 册:2013-5-15
收藏
得分:0 
没人么??没人么??没人吗??

C plus plus
2017-02-16 15:57
rjsp
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
等 级:版主
威 望:528
帖 子:9025
专家分:54030
注 册:2011-1-18
收藏
得分:4 
你将 std::srand((unsigned)time(0));
替换成 std::srand(1487231414); 看看输出什么
替换成 std::srand(1487231496); 看看输出什么
2017-02-16 16:16
幻楚
Rank: 1
等 级:新手上路
帖 子:59
专家分:0
注 册:2013-5-15
收藏
得分:0 
回复 4楼 rjsp
运行结果:
system time : 1487234205
6 0 3 5 7 8 4 1 2 9
Program ended with exit code: 0
 
我试过直接使用 std::srand() 括号防止固定数,或者将 这句注释掉,运行结果都是上面这个,感觉我的 std::srand() 没有起作用。

C plus plus
2017-02-16 16:38
xzlxzlxzl
Rank: 15Rank: 15Rank: 15Rank: 15Rank: 15
来 自:湖北
等 级:贵宾
威 望:125
帖 子:1091
专家分:5825
注 册:2014-5-3
收藏
得分:4 
我每次运行的结果都不一样,如下:

system time : 1487247937
8 5 9 2 3 0 6 1 7 4
system time : 1487247944
4 8 1 7 2 5 3 6 0 9
system time : 1487247951
6 1 2 8 0 5 7 3 9 4

不过为了能正常运行你的程序,我加了好多头文件,在我电脑上正常运行的代码如下:
程序代码:
#include "StdAfx.h"
#include <iostream>
#include <vector>
#include <iterator>
#include <algorithm>
#include <time.h>
int main()
{
    std::srand((unsigned)time(0));  // 这句话没有起作用,我试过用一个固定值或者注释掉这句话,生成的序列都是一样的 
    std::cout << "system time : " << time(0) << std::endl;
    
    std::vector<int> v;
    std::ostream_iterator<int> out_iter(std::cout, " ");

    for(int i=0; i<10; ++i)
    {
        v.push_back(i);
    }
    
    std::random_shuffle(v.begin(), v.end());
    
    copy(v.begin(), v.end(), out_iter);
    
    std::cout << "\n";
    return 0;
}
2017-02-16 20:27
yangfrancis
Rank: 16Rank: 16Rank: 16Rank: 16
等 级:贵宾
威 望:141
帖 子:1510
专家分:7661
注 册:2014-5-19
收藏
得分:4 
在shuffle之前随便哪里任意加一个getch()吃个回车键应该就可以了
2017-02-17 09:55
快速回复:C++ shuffle算法问题
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.039285 second(s), 8 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved