• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            唐吉訶德

              C++博客 :: 首頁 :: 聯(lián)系 :: 聚合  :: 管理
              5 Posts :: 75 Stories :: 3 Comments :: 0 Trackbacks

            常用鏈接

            留言簿(2)

            我參與的團隊

            搜索

            •  

            最新評論

            閱讀排行榜

            評論排行榜

             

            大家都知道C語言中的隨機函數(shù)random,可是random函數(shù)并不是ANSI C標準,所以說,random函數(shù)不能在gcc,vc等編譯器下編
            譯通過。那么怎么實現(xiàn)VC語言中的隨機函數(shù)呢?

            其實,除了random函數(shù),還有一個rand函數(shù),這個函數(shù)也是一個隨機函數(shù),他可以產(chǎn)生從0到rand_max(32767)的隨機數(shù)。

             

            #include<stdio.h>
            #include
            <stdlib.h>

            int main()

               
            int k; 
               k 
            = rand();
               printf(
            "%d\\n", k);
               
            return 0;
            }
            //main

            大家可以把以上的代碼編譯運行一下,發(fā)現(xiàn)他的確產(chǎn)生隨機數(shù)了,但是你會發(fā)現(xiàn),每次運行程序產(chǎn)生的隨機數(shù)都是一樣的,不過你在程序里加上for循環(huán),每次產(chǎn)生的數(shù)不一樣,但是,如果再運行這個程序,它產(chǎn)生的數(shù)據(jù)卻都是相同的。

            那么如何寫一個程序,讓它每次運行時產(chǎn)生的隨機數(shù)都不一樣呢? 請看下面的例子:

            #include <stdlib.h>
            #include 
            <stdio.h>
            #include 
            <time.h>
            #include
            <iostream>
            using namespace std;
            int main(void)
            {
               
            int i;
               time_t t;
               srand((unsigned) time(
            &t));
              cout
            <<"Ten random numbers from 0 to 99\n\n";
               
            for(i=0; i<10; i++)
                   printf(
            "%d\n", rand() % 100);
               
            return 0;
            }

            這時運行程序,會發(fā)現(xiàn)每次產(chǎn)生的隨機數(shù)都不一樣。

            那么為什么第一個程序一樣而第二個程序一樣呢?

            第二個程序用到了一個新的函數(shù)srand

            這個函數(shù)是給隨機數(shù)產(chǎn)生一個隨機種子(seed),函數(shù)原型是srand( (unsigned)time( NULL ) );


            time的值每時每刻都不同。所以種子不同,所以,產(chǎn)生的隨機數(shù)也不同。

            所以說,要想產(chǎn)生不同的隨機數(shù),在使用rand之前需要先調(diào)用srand

            srand和rand函數(shù)都包含在stdlib.h的頭文件里。

            由于rand產(chǎn)生的隨機數(shù)是從0到rand_max的,而rand_max(32767)是一個很大的數(shù),那么如何產(chǎn)生從X~Y的數(shù)呢?

            從X到Y,有Y-X+1個數(shù),所以要產(chǎn)生從X到Y的數(shù),只需要這樣寫:

            k = rand() % (Y - X + 1) +X;

            這樣,就可以產(chǎn)生你想要的任何范圍內(nèi)的隨機數(shù)了。
            問題:如何生成K個小于N并且互不重復的整數(shù)

            一.首先對于c++的隨機函數(shù)我們要有所了解,這里就不累贅了,請讀者自行google之,
            我們要用到的有
            1. void srand(unsigned int_seed)函數(shù)產(chǎn)生一個以當前時間開始的隨機種子
              srand(unsigned(time(NULL))),必須放在生成隨機數(shù)前
            2.int rand()函數(shù),隨機產(chǎn)生一整數(shù)
               rand()%MAX 產(chǎn)生[0,MAX)的整數(shù)
               a+rand()%(b-a+1) 產(chǎn)生[a,b]之間的整數(shù)
            3.需要頭文件#include<time.h>

            #include<iostream>
            using namespace std;
            #include
            <time.h>
            #define N 100
            #define K 20

            int x[N];
            void swap(int i,int j)
            {
              
            int temp=x[i];
              x[i]
            =x[j];
              x[j]
            =temp;
            }

            int main()
            {
                
            int i;
                
            for(i=0;i<N;i++)
                    x[i]
            =i;
                srand(unsigned(time(NULL)));
                
            for(i=0;i<K;i++){
                    swap(i,i
            +rand()%(N-i));
                    cout
            <<x[i]<<" ";
                }

                
                
            return 0;
            }


            二.考慮如何讓數(shù)據(jù)不重復 
              看代碼吧。。學習下方法
            首先搞個一絕沒有重復數(shù)據(jù)的數(shù)組,就是x[i]=i;
            此時注意那個swap函數(shù),每次生成的隨機數(shù)作為數(shù)組下標去取數(shù),然后交換,這就保證了x這個數(shù)組絕不會有重復的數(shù)出現(xiàn)。
            絕了!!

            posted on 2010-05-02 11:10 心羽 閱讀(6964) 評論(1)  編輯 收藏 引用 所屬分類: C/C++

            Feedback

            # re: C/C++/VC隨機數(shù)總結 2012-03-28 17:12 游客
            for(i=0;i<K;i++){
            swap(i,i+rand()%(N-i));
            cout<<x[i]<<" ";
            }
            這段代碼不嚴謹!正確如下:
            for(i=0;i<K;i++){
            swap(i,i+rand()%(N-i));
            }
            for(i=0;i<K;i++){
            cout<<x[i]<<" ";
            }
              回復  更多評論
              

            久久精品国产99国产精品亚洲| 久久99九九国产免费看小说| 久久精品国产亚洲av高清漫画| 亚洲精品白浆高清久久久久久 | 久久久久亚洲AV成人网| 久久久久久久久66精品片| 久久国产亚洲精品麻豆| 伊人久久亚洲综合影院| 亚洲国产天堂久久综合网站| 亚洲综合日韩久久成人AV| 人妻精品久久久久中文字幕| 亚洲狠狠综合久久| 99精品久久久久久久婷婷| 久久精品国产秦先生| 亚洲av成人无码久久精品| 国产精品99久久久久久猫咪| 久久天堂电影网| 久久精品国产亚洲AV无码娇色 | 国产综合精品久久亚洲| 国产∨亚洲V天堂无码久久久| 精品无码久久久久国产动漫3d| 国产成人精品久久一区二区三区av | 一级做a爰片久久毛片看看| 久久九九有精品国产23百花影院| 久久精品无码一区二区WWW| 久久久久国产一区二区| 国产精自产拍久久久久久蜜| 久久无码国产专区精品| 性做久久久久久久久| 久久久久久久综合日本| 久久精品国产WWW456C0M| 国产精品久久久久久久午夜片 | 国产成人无码精品久久久免费 | 久久中文字幕人妻丝袜| 欧美午夜A∨大片久久| 久久e热在这里只有国产中文精品99| 久久综合综合久久97色| 国产精品美女久久久久AV福利| 色综合久久最新中文字幕| 久久九九有精品国产23百花影院| 99久久国产综合精品网成人影院|