1

0からTotalfriendsまでの乱数を生成する次のコードを使用しています。乱数を取得したいのですが、繰り返さないでください。どのようにアイデアはありますか?

これは私が使用しているコードです

FB.getLoginStatus(function(response) {
    var profilePicsDiv = document.getElementById('profile_pics');
FB.api({ method: 'friends.get' }, function(result) {

     // var result =resultF.data;
   // console.log(result);
   var user_ids="" ;
   var totalFriends = result.length;
   // console.log(totalFriends);
   var numFriends = result ? Math.min(25, result.length) : 0;
  // console.log(numFriends);
   if (numFriends > 0) {
      for (var i=0; i<numFriends; i++) {
        var randNo = Math.floor(Math.random() * (totalFriends + 1))
        user_ids+= (',' + result[randNo]);
         console.log(user_ids);

          }
        }
        profilePicsDiv.innerHTML = user_ids;
      });
});
4

4 に答える 4

3

arrayこれは、フィッシャーイェーツシャッフルに基づいて、からn個のランダムな要素を取得し、それらを返す関数です。array引数が変更されることに注意してください。

function randomFrom(array, n) {
    var at = 0;
    var tmp, current, top = array.length;

    if(top) while(--top && at++ < n) {
        current = Math.floor(Math.random() * (top - 1));
        tmp = array[current];
        array[current] = array[top];
        array[top] = tmp;
    }

    return array.slice(-n);
}

あなたのコードが私が思うように機能すると仮定すると、あなたはすでにユーザーIDの配列を持っています:

var random10 = randomFrom(friendIds, 10);
于 2012-05-25T14:34:43.260 に答える
2
  1. yourarray範囲内の数値の配列(例)を作成します[1..totalfriends]
  2. 配列をシャッフルします(たとえば、Fisher-Yatesアルゴリズムのjavascript実装を使用します)
  3. for(from 0to yourarray.length - 1)内でpop()配列からaを作成する(または単にn-th要素を取得する)ので、毎回異なる数を取得します

そうすることで、重複した番号を取得することを回避できます

于 2012-05-25T14:25:01.053 に答える
0

ランダムな反復を実行し、次のようにすべての数値を含む配列を作成します。

var friendIndexes = [];

for (var i=0; i<numFriends; i++)
{
   friendIndexes.push(i);
}

次に、すべての数値の配列ができたら、2つの乱数を生成し、それらのインデックスの値を交換する、数回の反復(おそらく1,000回)を実行します。

for (var s = 0; s<1000; s++)
{
    var rnd1 = Math.floor(Math.random() * (numFriends + 1);
    var rnd2 = Math.floor(Math.random() * (numFriends + 1);

    // Swap the two values (remember to use a temp variable)
    var tmp = friendIndexes[rnd1];
    friendIndexes[rnd1] = friendIndexes[rnd2];
    friendIndexes[rnd2] = tmp;
}

あなたは本質的にそれらをシャッフルしている、そして結果はあなたにランダムな順序であなたに番号を与えるだろう。

于 2012-05-25T14:25:36.907 に答える
0

numFriendsを分割しない大きな数、または単に大きな素数(702038、727699、992700、1201046、1232255、2312734、3136255、4235414、6090515など)を取得します。

var result=[] ;
var K=Math.floor((Math.random()*bigUnNumFreindsDivider) ;

for (var i=0; i<numFriends; i++)
{
    result[i]=(i*bigUnNumFreindsDivider+K)%numFreinds ;
}

これは正常に機能するはずです。

于 2012-05-25T17:00:19.823 に答える