2016年4月21百度iOS實習生線上筆試題&編程題

来源:http://www.cnblogs.com/iOSlearner/archive/2016/04/21/5419088.html
-Advertisement-
Play Games

1.一個人上臺階可以一次上1個,2個,或者3個,問這個人上32層的臺階,總共有幾種走法? 思路:先建立數學模型,設3步的走 i 次,2步的走 j 次, 1步的走 k 次,上了3*i + 2*j + 1*k = n個臺階.總共走 i + j + k 次, 等於把n個臺階的長度先劃分成 i + j + ...


1.一個人上臺階可以一次上1個,2個,或者3個,問這個人上32層的臺階,總共有幾種走法?

思路:先建立數學模型,設3步的走 i 次,2步的走 j 次, 1步的走 k 次,上了3*i + 2*j + 1*k = n個臺階.總共走 i + j + k 次, 等於把n個臺階的長度先劃分成 i + j + k 個段落, 然後分別填下i個3, j 個2, k個1.這樣,當劃分成 i + j + k 個段落時, 根據排列組合知識,所有填充方法有 (i + j + k )!/ ( i!*j!*k!) 種,程式中使用GetComb(i,j,k)函數計算此值.
對於i, j, k的確定,我們可以用從大到小劃分法, 先劃分3的次數,再劃分2的次數,剩下的都算做1的次數,具體程式中就是裡面的i,j,兩重迴圈.

 1 #include <iostream>
 2 #include  <cstdio>
 3 int Factorial(int n)
 4 {
 5     int ret = n;
 6     if (n<=1)
 7     {
 8         return 1;
 9     }
10     while (n-->1)
11     {
12         ret*=n;
13     }
14     return ret;
15 }
16 
17 //求(i+j+k)!/(i!*j!*k!)
18 
19 int GetComb(int i,int j,int k)
20 {
21     int m = Factorial(i+j+k);
22     int l =  Factorial(i)*Factorial(j)*Factorial(k);
23     return m/l;
24 }
25 
26 
27 int NStepFor123(int n)
28 {
29     int i=0;
30     int j=0;
31     int p;
32     int k;
33     int result=0;
34     for ( i=0; i<=n/3; i++ )
35     {
36         p = n-i*3;
37         for ( j=0; j<=p/2; j++ )
38         {
39             k = p -j*2;
40             //求(i+j+k)!/(i!*j!*k!)
41             result += GetComb(i,j,k);
42         }
43     }  
44     return result;  
45 }
46 int main(int argc, const char * argv[]) {
47     // insert code here...
48     printf("%d",NStepFor123(32));
49     return 0;
50 }

 此題還可以有另一種方法

f(n) = f(n-1)+f(n-2)+f(n-3),特別地f(0)=1;f(1)=1;f(2)=2;
式子的證明為:增加一步共為f(n+1)的時候,把這新的一步算進去後有三種情況,1是這一步僅當一步走為f(n)次,2是這一步配合原來的最後一步作為兩步走為f(n-1)次,3是這一步配合前面的兩步作三步走為f(n-2);所以式子f(n+1) =f(n)+ f(n-1)+f(n-2),歸納得證。

int f (int k)
{
   int v[3]={1,1,2};
    long index = -1;
    if (k<0)
    {
        return 0;
    }
    
    if (k<3)
    {
        return v[k];
    }
    
    while(k-->2)
    {
        index++;
        index %= 3;
        v[index] = v[0]+v[1]+v[2];
    }
    return v[index];
}
int main(int argc, const char * argv[]) {

    printf("%d",f(32));
    return 0;
}

奇怪的是兩個程式運行結果不一致

調試發現前1~13結果一致。由於第二種O(n)所以應是第一種出現問題。

int Factorial(int n) int 不能裝下ret所以出錯,把它改成 long型就ok了
代碼如下
long Factorial(int n)
{
   long ret = n;
    if (n<=1)
    {
        return 1;
    }
    while (n-->1)
    {
        ret*=n;
    }
    return ret;
}


//求(i+j+k)!/(i!*j!*k!)

double GetComb(int i,int j,int k)
{
   double m = Factorial(i+j+k);
    double l =  Factorial(i)*Factorial(j)*Factorial(k);
    return m/l;
}


long NStepFor123(int n)
{
    int i=0;
    int j=0;
    int p;
    int k;
    long result=0;
    for ( i=0; i<=n/3; i++ )
    {
        p = n-i*3;
        for ( j=0; j<=p/2; j++ )
        {
            k = p -j*2;
            //求(i+j+k)!/(i!*j!*k!)
            result += GetComb(i,j,k);
        }
    }
    return result;
}
int main()
{
    
    printf("%ld",NStepFor123(32));
    
    
    return 0;
}
但我們發現在32時仍然不相等,說明階乘運算得出的ret又大於long的取值了,int64_t仍然不夠用,所以要用字元串模擬大數(會很麻煩)
所以建議使用第二種也就是遞歸的方法解決問題。

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 作者nuptboyzhb,源碼newplanegame,新版飛機大戰是一款以真實戰機為模板的飛行射擊類游戲,體驗新穎,玩法炫酷。一樣的經典,不一樣的體驗。飛機模型基於目前的主流戰機:包括美國F16,F22,法國幻影2000等機型模型,真實機型任你選。 源碼下載:http://code.662p.co ...
  • Fragment 源碼:http://www.jinhusns.com/Products/Download/?type=xcj Android是在Android 3.0 (API level 11)開始引入Fragment的。 可以把Fragment想成Activity中的模塊,這個模塊有自己的佈局 ...
  • 一,效果圖。 二,工程圖。 三,代碼。 RootViewController.h #import <UIKit/UIKit.h> @interface RootViewController : UIViewController <UIScrollViewDelegate,UITableViewDel ...
  • 關於方法前的 + - 符號 MyClass.alloc().init(foo.bar()).autorelease(); ...
  • 很多人一提到Binder就說代理模式,人云亦云的多,能理解精髓的少。 本篇文章就從設計角度分析一下java層BInder的設計目標,以及設計思路,設計缺陷,從而駕馭它。 對於【邦德兒】的理解, 從通信的角度來看,就是一種通信方式而已,與socket沒有任何區別。客戶端transact,服務端onTr ...
  • 通過使用單行代碼完成同樣的 10 個練習,我們來看看 Swift 和其他語言之間的較量。 將數組中每個元素的值乘以 2 使用map來實現 代碼簡單明瞭地完成了數組元素乘2 求一組數字的和 這個問題可以通過使用 reduce 方法和加號運算符解決,這是因為加號運算符實際上也是一個函數。不過這個解法是非 ...
  • 使用小米號碼歸屬地資料庫,有兩張表data1和data2 先查詢data1表,把手機號碼截取前7位 select outkey from data1 where id=”前七位手機號” 再查詢data2表, select location from data2 where id=”上面查出的outk ...
  • 一、前言部分 沒發現蒲公英之前一直採用非常傻B的方式給公司App做內部測試,要麼發個測試包讓公司測試人員用iTUnes 自己安裝 要麼苦逼的一個個在我Xcode上直接安裝測試包,操作起來又麻煩又苦逼,後來偶然發現了蒲公英感覺這貨還真不是一般 好用。直接上傳測試文件到他們平臺上傳成功後直接將測試地址發 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...