浅谈php随机不重复数的两种算法
先引入别人的一个秒表计时类(counttime.class.php): 1.先看第一个例子(大数中取少数): 1 ? 2 /* 3 @描述: Stopwatch这个类用户获取脚本执行时间 4 @作者: Klesti Hoxha klesti@gmail.com 5 */ 6 7 class Stopwatch { 8 private $start ; 9 private $en
先引入别人的一个秒表计时类(counttime.class.php):
1.先看第一个例子(大数中取少数):
<span> 1</span> <span> 2</span> <span>/*</span> <span> 3</span> <span>@描述: Stopwatch这个类用户获取脚本执行时间 </span><span> 4</span> <span>@作者: Klesti Hoxha <klesti> </klesti></span><span> 5</span> <span>*/</span> <span> 6</span> <span> 7</span> <span>class</span><span> Stopwatch { </span><span> 8</span> <span>private</span> <span>$start</span><span>; </span><span> 9</span> <span>private</span> <span>$end</span><span>; </span><span>10</span> <span>private</span> <span>$markup_start</span> = <span>array</span><span>(); </span><span>11</span> <span>private</span> <span>$markup_end</span> = <span>array</span><span>(); </span><span>12</span> <span>13</span> <span>function</span> __construct(<span>$markup</span>=<span>false</span><span>) { </span><span>14</span> <span>$this</span>->start(<span>$markup</span><span>); </span><span>15</span> <span>} </span><span>16</span> <span>17</span> <span>public</span> <span>function</span> start(<span>$markup</span>=<span>false</span><span>) { </span><span>18</span> <span>if</span> (!<span>$markup</span><span>) { </span><span>19</span> <span>$this</span>->start = <span>$this</span>-><span>getmicrotime(); </span><span>20</span> } <span>else</span><span> { </span><span>21</span> <span>$this</span>->markup_start[<span>$markup</span>] = <span>$this</span>-><span>getmicrotime(); </span><span>22</span> <span>} </span><span>23</span> <span>} </span><span>24</span> <span>25</span> <span>public</span> <span>function</span> stop(<span>$markup</span>=<span>false</span><span>) { </span><span>26</span> <span>if</span> (!<span>$markup</span><span>) { </span><span>27</span> <span>$this</span>-><span>end</span> = <span>$this</span>-><span>getmicrotime(); </span><span>28</span> } <span>else</span><span> { </span><span>29</span> <span>$this</span>->markup_end[<span>$markup</span>] = <span>$this</span>-><span>getmicrotime(); </span><span>30</span> <span>} </span><span>31</span> <span>return</span> <span>$this</span>->getDuration(<span>$markup</span><span>); </span><span>32</span> <span>} </span><span>33</span> <span>34</span> <span>public</span> <span>function</span> getDuration(<span>$markup</span>=<span>false</span><span>) { </span><span>35</span> <span>if</span> (!<span>$markup</span><span>) </span><span>36</span> <span> { </span><span>37</span> <span>return</span> <span>number_format</span>(<span>$this</span>-><span>end</span>-<span>$this</span>->start,4<span>); </span><span>38</span> } <span>else</span><span> { </span><span>39</span> <span>return</span> <span>number_format</span>(<span>$this</span>->markup_end[<span>$markup</span>]-<span>$this</span>->markup_start[<span>$markup</span>],4<span>); </span><span>40</span> <span> } </span><span>41</span> <span>} </span><span>42</span> <span>43</span> <span>public</span> <span>function</span> <span>reset</span>(<span>$markup</span><span>) { </span><span>44</span> <span>if</span> (!<span>$markup</span><span>) { </span><span>45</span> <span>$this</span>->start = 0<span>; </span><span>46</span> <span>$this</span>-><span>end</span> = 0<span>; </span><span>47</span> <span>$this</span>->markup_start = <span>array</span><span>(); </span><span>48</span> <span>$this</span>->markup_end = <span>array</span><span>(); </span><span>49</span> } <span>else</span><span> { </span><span>50</span> <span>$this</span>->markup_start[<span>$markup</span>] = 0<span>; </span><span>51</span> <span>$this</span>->markup_end[<span>$markup</span>] = 0<span>; </span><span>52</span> <span>} </span><span>53</span> <span>} </span><span>54</span> <span>55</span> <span>private</span> <span>function</span><span> getmicrotime(){ </span><span>56</span> <span>list</span>(<span>$usec</span>, <span>$sec</span>) = <span>explode</span>(" ",<span>microtime</span><span>()); </span><span>57</span> <span>return</span> ((<span>float</span>)<span>$usec</span> + (<span>float</span>)<span>$sec</span><span>); </span><span>58</span> <span>} </span><span>59</span> <span>60</span> <span>} </span><span>61</span> ?>
测试的两种方法如下:
<span> 1</span> <meta http-equiv="Content-Type" content="text/html; charset=utf-8"> <span> 2</span> <span>php </span><span> 3</span> <span>require</span> "counttime.class.php";<span>//</span><span>把类文件引用进来,根据你的实际情况来确定路径,这里是在同级目录</span> <span> 4</span> <span>$s</span> = <span>new</span><span> Stopwatch(); </span><span> 5</span> <span> 6</span> <span>$s</span>->start("div1"<span>); </span><span> 7</span> <span>//</span><span>range 是将1到100 列成一个数组</span> <span> 8</span> <span>$numbers</span> = <span>range</span> (1,1000000<span>); </span><span> 9</span> <span>//</span><span>shuffle 将数组顺序随即打乱</span> <span>10</span> <span>shuffle</span> (<span>$numbers</span><span>); </span><span>11</span> <span>//</span><span>array_slice 取该数组中的某一段</span> <span>12</span> <span>$no</span>=30<span>; </span><span>13</span> <span>$result</span> = <span>array_slice</span>(<span>$numbers</span>,0,<span>$no</span><span>); </span><span>14</span> <span>for</span> (<span>$i</span>=0;<span>$i</span>$no;<span>$i</span>++<span>){ </span><span>15</span> <span>echo</span> <span>$result</span>[<span>$i</span>]."<br>"<span>; </span><span>16</span> <span>} </span><span>17</span> <span>echo</span> "第一个测验方法结束<br><br>"<span>; </span><span>18</span> <span>$s</span>->stop("div1"<span>); </span><span>19</span> <span>20</span> <span>$s</span>->start("div2"<span>); </span><span>21</span> <span>function</span> unique_rand(<span>$min</span>, <span>$max</span>, <span>$num</span><span>) </span><span>22</span> <span>{ </span><span>23</span> <span>$count</span> = 0<span>; </span><span>24</span> <span>$return</span> = <span>array</span><span>(); </span><span>25</span> <span>while</span> (<span>$count</span> $num<span>) { </span><span>26</span> <span>$return</span>[] = <span>mt_rand</span>(<span>$min</span>, <span>$max</span><span>); </span><span>27</span> <span>$return</span> = <span>array_flip</span>(<span>array_flip</span>(<span>$return</span><span>)); </span><span>28</span> <span>$count</span> = <span>count</span>(<span>$return</span><span>); </span><span>29</span> <span> } </span><span>30</span> <span>shuffle</span>(<span>$return</span><span>); </span><span>31</span> <span>return</span> <span>$return</span><span>; </span><span>32</span> <span>} </span><span>33</span> <span>34</span> <span>$arr</span> = unique_rand(1, 100000000000, 30<span>); </span><span>35</span> <span>$result</span> = ''<span>; </span><span>36</span> <span>for</span>(<span>$i</span>=0; <span>$i</span> count(<span>$arr</span>);<span>$i</span>++<span>) </span><span>37</span> <span> { </span><span>38</span> <span>$result</span> = <span>$arr</span>[<span>$i</span><span>]; </span><span>39</span> <span>echo</span> <span>$result</span>."<br>"<span>; </span><span>40</span> <span> } </span><span>41</span> <span>$s</span>->stop("div2"<span>); </span><span>42</span> <span>43</span> <span>44</span> <span>//</span><span>输出时间</span> <span>45</span> <span>echo</span> "div 1 Duration: " . <span>$s</span>->getDuration("div1") . " seconds.<br>"<span>; </span><span>46</span> <span>echo</span> "div 2 Duration: " . <span>$s</span>->getDuration("div2") . " seconds.<br>"<span>; </span><span>47</span> ?>
结果为:
<span> 1</span> 413537 <span> 2</span> 198587 <span> 3</span> 60611 <span> 4</span> 599544 <span> 5</span> 946241 <span> 6</span> 462853 <span> 7</span> 570943 <span> 8</span> 980260 <span> 9</span> 717416 <span>10</span> 969324 <span>11</span> 292403 <span>12</span> 614443 <span>13</span> 769469 <span>14</span> 151951 <span>15</span> 167883 <span>16</span> 308727 <span>17</span> 342706 <span>18</span> 955659 <span>19</span> 112311 <span>20</span> 329008 <span>21</span> 182668 <span>22</span> 330600 <span>23</span> 921966 <span>24</span> 993143 <span>25</span> 369227 <span>26</span> 747066 <span>27</span> 793185 <span>28</span> 347872 <span>29</span> 439016 <span>30</span> 428600 <span>31</span> <span>第一个测验方法结束 </span><span>32</span> <span>33</span> 649589727 <span>34</span> 450823813 <span>35</span> 324717181 <span>36</span> 44553762 <span>37</span> 375669657 <span>38</span> 37128612 <span>39</span> 25135327 <span>40</span> 468454185 <span>41</span> 73395357 <span>42</span> 753960006 <span>43</span> 214455797 <span>44</span> 5367614 <span>45</span> 1153263961 <span>46</span> 17803441 <span>47</span> 669057198 <span>48</span> 55366324 <span>49</span> 1117343950 <span>50</span> 203530485 <span>51</span> 1160930064 <span>52</span> 326487914 <span>53</span> 565471236 <span>54</span> 7068443 <span>55</span> 846955001 <span>56</span> 832037489 <span>57</span> 1067813034 <span>58</span> 219239595 <span>59</span> 1069795964 <span>60</span> 1049898846 <span>61</span> 926301266 <span>62</span> 197341539 <span>63</span> div 1 Duration: 0.5800 seconds. <span>64</span> div 2 Duration: 0.0000 seconds.
结论:对于从大量数据中取少量数据,显然第二种比较快。
2.在来看看从大数中取大数:
<span> 1</span> <meta http-equiv="Content-Type" content="text/html; charset=utf-8"> <span> 2</span> <span>php </span><span> 3</span> <span>require</span> "counttime.class.php";<span>//</span><span>把类文件引用进来,根据你的实际情况来确定路径,这里是在同级目录</span> <span> 4</span> <span>$s</span> = <span>new</span><span> Stopwatch(); </span><span> 5</span> <span> 6</span> <span>$s</span>->start("div1"<span>); </span><span> 7</span> <span>//</span><span>range 是将1到100 列成一个数组</span> <span> 8</span> <span>$numbers</span> = <span>range</span> (1,1000000<span>); </span><span> 9</span> <span>//</span><span>shuffle 将数组顺序随即打乱</span> <span>10</span> <span>shuffle</span> (<span>$numbers</span><span>); </span><span>11</span> <span>//</span><span>array_slice 取该数组中的某一段</span> <span>12</span> <span>$no</span>=10000<span>; </span><span>13</span> <span>$result</span> = <span>array_slice</span>(<span>$numbers</span>,0,<span>$no</span><span>); </span><span>14</span> <span>for</span> (<span>$i</span>=0;<span>$i</span>$no;<span>$i</span>++<span>){ </span><span>15</span> <span>echo</span> <span>$result</span>[<span>$i</span>]."<br>"<span>; </span><span>16</span> <span>} </span><span>17</span> <span>echo</span> "第一个测验方法结束<br><br>"<span>; </span><span>18</span> <span>$s</span>->stop("div1"<span>); </span><span>19</span> <span>20</span> <span>$s</span>->start("div2"<span>); </span><span>21</span> <span>function</span> unique_rand(<span>$min</span>, <span>$max</span>, <span>$num</span><span>) </span><span>22</span> <span>{ </span><span>23</span> <span>$count</span> = 0<span>; </span><span>24</span> <span>$return</span> = <span>array</span><span>(); </span><span>25</span> <span>while</span> (<span>$count</span> $num<span>) { </span><span>26</span> <span>$return</span>[] = <span>mt_rand</span>(<span>$min</span>, <span>$max</span><span>); </span><span>27</span> <span>$return</span> = <span>array_flip</span>(<span>array_flip</span>(<span>$return</span><span>)); </span><span>28</span> <span>$count</span> = <span>count</span>(<span>$return</span><span>); </span><span>29</span> <span> } </span><span>30</span> <span>shuffle</span>(<span>$return</span><span>); </span><span>31</span> <span>return</span> <span>$return</span><span>; </span><span>32</span> <span>} </span><span>33</span> <span>34</span> <span>$arr</span> = unique_rand(1, 1000000, 10000<span>); </span><span>35</span> <span>$result</span> = ''<span>; </span><span>36</span> <span>for</span>(<span>$i</span>=0; <span>$i</span> count(<span>$arr</span>);<span>$i</span>++<span>) </span><span>37</span> <span> { </span><span>38</span> <span>$result</span> = <span>$arr</span>[<span>$i</span><span>]; </span><span>39</span> <span>echo</span> <span>$result</span>."<br>"<span>; </span><span>40</span> <span> } </span><span>41</span> <span>$s</span>->stop("div2"<span>); </span><span>42</span> <span>43</span> <span>44</span> <span>//</span><span>输出时间</span> <span>45</span> <span>echo</span> "div 1 Duration: " . <span>$s</span>->getDuration("div1") . " seconds.<br>"<span>; </span><span>46</span> <span>echo</span> "div 2 Duration: " . <span>$s</span>->getDuration("div2") . " seconds.<br>"<span>; </span><span>47</span> ?>
输出结果为:
<span>1</span> <span>前面省略……………… </span><span>2</span> div 1 Duration: 0.6050 seconds. <span>3</span> div 2 Duration: 17.4260 seconds.
结论:对于第一种方法输出一个数据的时间,跟大数的数字时间差不多。但是第二个时间显然耗费得要离谱。达到了17.5秒。
总结:
1.翻翻法对于选少量数据好用,大量数据就会比较吃力。

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

JWT是一種基於JSON的開放標準,用於在各方之間安全地傳輸信息,主要用於身份驗證和信息交換。 1.JWT由Header、Payload和Signature三部分組成。 2.JWT的工作原理包括生成JWT、驗證JWT和解析Payload三個步驟。 3.在PHP中使用JWT進行身份驗證時,可以生成和驗證JWT,並在高級用法中包含用戶角色和權限信息。 4.常見錯誤包括簽名驗證失敗、令牌過期和Payload過大,調試技巧包括使用調試工具和日誌記錄。 5.性能優化和最佳實踐包括使用合適的簽名算法、合理設置有效期、

靜態綁定(static::)在PHP中實現晚期靜態綁定(LSB),允許在靜態上下文中引用調用類而非定義類。 1)解析過程在運行時進行,2)在繼承關係中向上查找調用類,3)可能帶來性能開銷。

PHP的魔法方法有哪些? PHP的魔法方法包括:1.\_\_construct,用於初始化對象;2.\_\_destruct,用於清理資源;3.\_\_call,處理不存在的方法調用;4.\_\_get,實現動態屬性訪問;5.\_\_set,實現動態屬性設置。這些方法在特定情況下自動調用,提升代碼的靈活性和效率。

PHP和Python各有優勢,選擇依據項目需求。 1.PHP適合web開發,尤其快速開發和維護網站。 2.Python適用於數據科學、機器學習和人工智能,語法簡潔,適合初學者。

PHP在電子商務、內容管理系統和API開發中廣泛應用。 1)電子商務:用於購物車功能和支付處理。 2)內容管理系統:用於動態內容生成和用戶管理。 3)API開發:用於RESTfulAPI開發和API安全性。通過性能優化和最佳實踐,PHP應用的效率和可維護性得以提升。

PHP是一種廣泛應用於服務器端的腳本語言,特別適合web開發。 1.PHP可以嵌入HTML,處理HTTP請求和響應,支持多種數據庫。 2.PHP用於生成動態網頁內容,處理表單數據,訪問數據庫等,具有強大的社區支持和開源資源。 3.PHP是解釋型語言,執行過程包括詞法分析、語法分析、編譯和執行。 4.PHP可以與MySQL結合用於用戶註冊系統等高級應用。 5.調試PHP時,可使用error_reporting()和var_dump()等函數。 6.優化PHP代碼可通過緩存機制、優化數據庫查詢和使用內置函數。 7

PHP仍然具有活力,其在現代編程領域中依然佔據重要地位。 1)PHP的簡單易學和強大社區支持使其在Web開發中廣泛應用;2)其靈活性和穩定性使其在處理Web表單、數據庫操作和文件處理等方面表現出色;3)PHP不斷進化和優化,適用於初學者和經驗豐富的開發者。

在PHP8 中,match表達式是一種新的控制結構,用於根據表達式的值返回不同的結果。 1)它類似於switch語句,但返回值而非執行語句塊。 2)match表達式使用嚴格比較(===),提升了安全性。 3)它避免了switch語句中可能的break遺漏問題,增強了代碼的簡潔性和可讀性。
