4

CPMシステムのように、ビュー数で広告するバナーがあります。たとえば、次のようになります。

i have 3 banner:
banner1 with 20.000 nr of views
banner2 with 10.000 nr of views
banner3 with 5.000 nr of views

そして私のウェブサイトでは、バナーはこの位置に表示されなければなりません(ページがリロードされたとき):

バナー1 バナー2 バナー1 バナー2 バナー3

閲覧数が多ければ出現確率も上がる

どうすればphpでこれを行うことができますか?

4

2 に答える 2

3

まず第一に、あなたのシステムはただ...ばかです。多くのビューを持つバナーを永続させますが、ビューが 0 またはほとんどない新しく作成されたバナーは選択される機会がなく、実際に表示されることはありません...

そうは言っても、次のような配列がある場合:

$banners = array
(
    'banner1' => 1,
    'banner2' => 2,
    'banner3' => 4,
    'banner4' => 8,
    'banner5' => 16,
);

次のような関数を使用して、1 つのバナーを慎重に選択できます。

function Probability($data)
{
    if (is_array($data) === true) {
        $result = 0;
        $probability = mt_rand(1, array_sum($data));

        foreach ($data as $key => $value) {
            $result += $value;

            if ($result >= $probability) {
                return $key;
            }
        }
    }

    return false;
}

使用法 ( @ CodePad.orgまたは@ IDEOneでテストしてください):

echo Probability($banners); // banner5

100回の実行からのサンプル:

Array
(
    [banner5] => 41
    [banner4] => 38
    [banner3] => 10
    [banner2] => 8
    [banner1] => 3
)
于 2010-05-02T02:49:19.120 に答える
2

これを行うPHPの方法は次のとおりです

あなたの配列は次のようになると想像しています...

$banners = array(

    array (
        'name' => 'banner1',
        'views' => 20
    ),
    array (
        'name' => 'banner2',
        'views' => 10
    ),
    array (
        'name' => 'banner3',
        'views' => 5
    )
);

この関数は基本的にバナーをループし、バナーのビュー数に関係なく、その配列インデックスの多くの項目が配列に追加されます。次に、ランダムなものが選択されます。ビュー数が多いアイテムほど、選択される可能性が高くなります。

function getWeightedRandom( $array ) {

    $universe_array = array();

    foreach ( $array as $k => $b ) {
        $universe += $b['views'];
        $universe_array = array_pad( $universe_array, $universe, $k );
}

    $rand = mt_rand( 0, count( $universe_array ) -1 );
    return $array[ $universe_array[ $rand ] ];

}


$r = getWeightedRandom($banners);
print_r($r);

シンプルな mysql オプションは次のとおりです。

select * from banners order by rand() * views desc limit 1

より多くのビューを持つバナーは、上位の結果になる可能性が高くなります

于 2010-05-02T00:03:35.647 に答える