自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

找程序員女神要QQ號(hào)碼,結(jié)果……

開(kāi)發(fā) 后端 前端 移動(dòng)開(kāi)發(fā)
我們組來(lái)了個(gè)美女程序員,我心里竊喜,哈哈這下機(jī)會(huì)來(lái)了。我在想怎么下手呢?好吧,還是從QQ號(hào)碼開(kāi)始,找到女神要到QQ號(hào),哈哈,我真是個(gè)天才~~~

引言

我們組來(lái)了個(gè)美女程序員,我心里竊喜,哈哈這下機(jī)會(huì)來(lái)了。我在想怎么下手呢?好吧,還是從QQ號(hào)碼開(kāi)始,找到女神要到QQ號(hào),哈哈,我真是個(gè)天才~~~

是這樣子滴

想法是美好的,現(xiàn)實(shí)是殘酷的,找女神要QQ號(hào)碼的時(shí)候,沒(méi)想到女神沒(méi)有直接給我,而是給了我出了道題(果真是程序員的交手~~ ~),題都給我了,做不出來(lái)的話,不但沒(méi)了和女神的接觸機(jī)會(huì),連賴以為生的基本技能——編程能力都被質(zhì)疑了~~~題目是這樣的:
給了一串?dāng)?shù)字(不是QQ號(hào)碼),根據(jù)下面規(guī)則可以找出QQ號(hào)碼:首先刪除***個(gè)數(shù),緊接著將第二個(gè)數(shù)放到這串?dāng)?shù)字的末尾,再將第三個(gè)數(shù)刪除,并將第四個(gè)數(shù)放到這串?dāng)?shù)字的末尾......如此循環(huán),知道剩下***一個(gè)數(shù),將***一個(gè)數(shù)也刪除,按照剛才刪除的順序,把這些數(shù)字連在一起就是女神的QQ號(hào)碼啦。

[[137432]]

 

就是這樣,女神給了一串?dāng)?shù)字631758924,現(xiàn)在要做的就是從這個(gè)數(shù)字中找出女神的QQ號(hào)碼了,方法有很多種,比如說(shuō)用9張卡片分別寫(xiě)上這9個(gè)數(shù)字,模擬題目的過(guò)程,可以算出來(lái),也可以用筆一個(gè)一個(gè)的去算~~~~

這些方法都太low了,顯示不出程序員的能力,還是寫(xiě)個(gè)程序比較酷一點(diǎn)(其實(shí)我是在想,要是下次再遇到一個(gè)女神出這樣的題目,程序就很方便了,哈哈~~~)

解決辦法

***種方法,采用數(shù)學(xué)的方法,根據(jù)題目的規(guī)律,循環(huán)下面的操作:取整=>取余=>取余*10+取整。。。。。取余取整的對(duì)象都是10的倍數(shù),根據(jù)位數(shù)而定,每次取整之后就是一位,循環(huán)直到數(shù)字等于0。

  1. <?php  
  2. $raw_num = 631758924;  
  3. $num = 0;  
  4. $devisor = 1;  
  5. while($devisor < $raw_num)  
  6. {  
  7.     $devisor *= 10;     //獲取最小的大于raw_num的10的倍數(shù)的整數(shù)  
  8. }  
  9.  
  10. while ($raw_num > 0) {  
  11.     $devisor /= 10;  
  12.     $next = floor($raw_num / $devisor); //獲取下一個(gè)數(shù)字  
  13.     $num = $num*10 + $next;             //計(jì)算”半成品“QQ號(hào)碼  
  14.     $raw_num = $raw_num % $devisor;  
  15.     $last = floor($raw_num * 10 / $devisor);    //移動(dòng)數(shù)字,拼接***的QQ號(hào)碼  
  16.  
  17.     $pre = $raw_num % (ceil($devisor / 10));  
  18.  
  19.     $raw_num = $pre * 10 + $last;     
  20. }  
  21. echo "恭喜你啦,成功獲取QQ號(hào)碼:{$num}";    //恭喜你啦,成功獲取QQ號(hào)碼:615947283 

利用隊(duì)列的FIFO獲取QQ號(hào)碼,根據(jù)題目的特性,剛好可以使用隊(duì)列來(lái)處理,隊(duì)列簡(jiǎn)單方便,而且更好理解。

  1. #include<stdio.h> 
  2. struct queue {  
  3.     int *data;  
  4.     int head;  
  5.     int tail;  
  6. };   
  7. int main()  
  8. {  
  9.     int num, i;  
  10.     printf("請(qǐng)輸出要破譯的QQ號(hào)碼長(zhǎng)度:");  
  11.     scanf("%d", &num);  
  12.       
  13.     struct queue q;  
  14.     q.data = (int *)malloc(sizeof(int)*(num*2-1));  //總共需要的數(shù)組長(zhǎng)度為num*2-1   
  15.     q.head = 0;  
  16.     q.tail = 0;  
  17.       
  18.     for(i=1;i<=num;i++)  
  19.     {  
  20.         scanf("%d", &q.data[q.tail]);  
  21.         q.tail++;  
  22.     }  
  23.       
  24.     printf("恭喜你啦,成功獲取QQ號(hào)碼:");   
  25.     while(q.head < q.tail)  
  26.     {  
  27.         printf("%d", q.data[q.head]);  
  28.         q.head++;  
  29.           
  30.         q.data[q.tail] = q.data[q.head];  
  31.         q.tail++;  
  32.         q.head++;  
  33.     }  
  34.     return 0;  
  35. }  
  36.  
  37. #下面是一個(gè)實(shí)驗(yàn)  
  38. 請(qǐng)輸出要破譯的QQ號(hào)碼長(zhǎng)度:9  
  39. 6  
  40. 3  
  41. 1  
  42. 7  
  43. 5  
  44. 8  
  45. 9  
  46. 2  
  47. 4  
  48. 恭喜你啦,成功獲取QQ號(hào)碼:615947283請(qǐng)按任意鍵繼續(xù). . . 

恭喜你啦,成功獲取QQ號(hào)碼:615947283請(qǐng)按任意鍵繼續(xù). . .

說(shuō)點(diǎn)啥

本文點(diǎn)子來(lái)自《啊哈!算法》中的第二章,***節(jié)【解密QQ號(hào)——隊(duì)列】,唯一的插圖也截取自本書(shū)。

------------------------------------分割線------------------------------------

21樓@逐影的js用了數(shù)組的push、shift也不錯(cuò)(略有修改),”先push后shift“:

  1. var n = "631758924";  
  2. var arr = [];  
  3. var res = [];  
  4.  
  5. for(var i=0; i<n.length; i++) {  
  6.     arr.push(n.charAt(i));  
  7. }  
  8.  
  9. while(arr.length) {  
  10.     if(arr.length !== 1) {  
  11.         res.push( arr.shift() );  
  12.         arr.push( arr.shift() );      
  13.     } else {  
  14.         res.push( arr.shift() );  
  15.     }  
  16. }     
  17. console.log(res.join('')); //615947283  

 

責(zé)任編輯:林師授 來(lái)源: 奔跑的Man的博客
相關(guān)推薦

2013-04-18 09:55:05

程序員

2015-08-18 09:23:39

程序員學(xué)英語(yǔ)

2022-12-08 20:16:43

2009-11-17 09:41:49

程序員的學(xué)歷

2020-12-08 10:35:29

程序員IT數(shù)據(jù)分析

2015-11-02 09:19:10

程序員JavaScript

2010-10-09 09:20:08

.NET

2015-07-20 10:11:08

程序員幸福

2015-10-19 17:49:43

程序員泡沫工資

2020-06-01 09:43:26

程序員互聯(lián)網(wǎng)系統(tǒng)

2015-12-02 10:02:30

程序員找工作

2013-08-20 09:33:59

程序員

2012-03-06 09:22:46

程序員

2020-01-19 10:54:17

CDN邊緣計(jì)算域名

2020-02-08 19:13:29

程序員搞明白CDN

2009-05-26 09:00:59

ScalaJava面向?qū)ο?/a>

2021-03-29 07:51:22

公司程序員微信群

2018-05-23 15:01:46

程序員WiFi生產(chǎn)商

2009-05-21 15:58:12

程序員工作經(jīng)驗(yàn)職場(chǎng)

2011-05-13 14:34:02

程序員
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)