一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|JAVA教程|ASP教程|

服務器之家 - 編程語言 - JAVA教程 - Java實現的權重算法(按權重展現廣告)

Java實現的權重算法(按權重展現廣告)

2019-12-17 13:15junjie JAVA教程

這篇文章主要介紹了Java實現的權重算法(按權重展現廣告),本文講解了算法實現原理和實現代碼,需要的朋友可以參考下

基本算法描述如下:

1、每個廣告增加權重
2、將所有匹配廣告的權重相加sum,
3、以相加結果為隨機數的種子,生成1~sum之間的隨機數rd
4、.接著遍歷所有廣告,訪問順序可以隨意.將當前節點的權重值加上前面訪問的各節點權重值得curWt,判斷curWt >=  rd,如果條件成立則返回當前節點,如果不是則繼續累加下一節點. 直到符合上面的條件,由于rd<=sum 因此一定存在curWt>=rd。
特別說明:

此算法和廣告的順序無關

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
import java.util.ArrayList;
import java.util.Collections;
import java.util.Comparator;
import java.util.LinkedHashMap;
import java.util.List;
import java.util.Map;
 
public class Test {
 
  /**
   * @param args
   */
  @SuppressWarnings("unchecked")
  public static void main(String[] args) {
    
    List<Node> arrNodes = new ArrayList<Node>();
    Node n = new Node(10, "測試1");
    arrNodes.add(n);
    n = new Node(20, "測試2");
    arrNodes.add(n);
    n = new Node(30, "測試3");
    arrNodes.add(n);
    n = new Node(40, "測試4");
    arrNodes.add(n);
    
    //Collections.sort(arrNodes, new Node());
    Map<String, Integer> showMap = null;
    int sum = getSum(arrNodes);
    int random = 0;
    Node kw = null;
    for(int k = 0; k < 20; k++) {
      showMap = new LinkedHashMap<String, Integer>();
      for(int i = 0; i < 100; i++) {
        random = getRandom(sum);
        kw = getKW(arrNodes, random);
        if(showMap.containsKey(kw.kw)) {
          showMap.put(kw.kw, showMap.get(kw.kw) + 1);
        } else {
          showMap.put(kw.kw, 1);
        }
        //System.out.println(i + " " +random + " " + getKW(arrNodes, random));
      }
      System.out.print(k + " ");
      System.out.println(showMap);
    }
  }
  
  public static Node getKW(List<Node> nodes, int rd) {
    Node ret = null;
    int curWt = 0;
    for(Node n : nodes){
      curWt += n.weight;
      if(curWt >= rd) {
        ret = n;
        break;
      }
    }
    return ret;
  }
  public static int getSum(List<Node> nodes) {
    int sum = 0;
    for(Node n : nodes)
      sum += n.weight;
    return sum;
  }
  public static int getRandom(int seed) {
    return (int)Math.round(Math.random() * seed);
  }
}
class Node implements Comparator{
  int weight = 0;
  String kw = "";
  
  public Node() {}
  
  public Node(int wt, String kw) {
    this.weight = wt;
    this.kw = kw;
  }
  public String toString(){
    StringBuilder sbBuilder = new StringBuilder();
    sbBuilder.append(" weight=").append(weight);
    sbBuilder.append(" kw").append(kw);
    return sbBuilder.toString();
  }
  public int compare(Object o1, Object o2) {
    Node n1 = (Node)o1;
    Node n2 = (Node)o2;
    if(n1.weight > n2.weight)
      return 1;
    else
      return 0;
  }
}

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 亚洲www视频 | 青草青青在线视频 | 夫妻性生活一级黄色片 | 国产一区二区视频在线观看 | 国产男女性特黄录像 | 精品久久日日躁夜夜躁AV | 五月最新女厕所高跟嘘嘘 | 久久 这里只精品 免费 | 国产精品欧美一区二区 | 亚洲第一色视频 | 国产小视频网站 | 希岛爱理作品在线观看 | 九九热在线观看视频 | 毛片网站大全 | 日本道在线播放 | 亚洲精品国产专区91在线 | 国产一级片在线 | 国产精品拍拍拍福利在线观看 | 暖暖日本在线观看免费 | 欧美一级裸片又黄又裸 | 手机在线观看国产精选免费 | 亚洲成人91 | 亚洲国产综合精品 | 金莲一级淫片aaaaaa | 亚久久伊人精品青青草原2020 | 国产视频99| 人与禽交3d动漫羞羞动漫 | 亚洲一级特黄特黄的大片 | 高清黄色直接看 | 小鸟酱在线播放 | 亚洲欧美日韩高清 | www国产精品 | 国产一级特黄aa大片在线 | 免费观看国产视频 | china外卖员gay帮口 | 精品国产在天天线在线麻豆 | 国产欧美日韩在线观看精品 | 疯狂伦交1一6 小说 风间由美在线 | 久久中文字幕无线观看 | 四虎永久 | 国产麻豆精品原创 |