C 解決百度知道的一個高中題

来源:http://www.cnblogs.com/life2refuel/archive/2016/01/19/5141429.html
-Advertisement-
Play Games

在百度知道上看到一個排列組合的一個提問,一想還是比較容易的主要採用取餘的方法. 這裡用C寫了一段代碼測試了一下.代碼比較水,主要看後面的數學分析. 想想還是高中生 的時候比較厲害,啥都會,啥都算的快. 現在打游戲都力不從心了. 同學們四年游戲專業一定要好好學.不留遺憾.


前言

  今天看見一道百度知道上提問,是這樣的.

仔細算了一下, 花了30min.才整齣來了,估計現在回去參加高考,數學及格都懸.有時候想做這樣的題有什麼用,

學這些東西有什麼意義,在這種方面浪費時間有什麼值得的.

後來想出來,

    開心就好!

想太多,考慮太多心累.我們開心就好.

 

正文

  第一部分 從代碼說開來

採用的主要思路是窮舉法,窮舉完之後,再判斷. 思考了一下,主要用 char str[5]; 保存這個這個串. 採用下麵函數檢測這個串

是否是想要的串

#inclue <stdbool.h>

// 串檢測函數
bool 
isaa(char str[], int len)
{
    int i = 0;
    while(++i < len)
        if (str[i] == 'a' && str[i - 1] == 'a') 
            return true;

    return false;
}

效率上也沒深入搞了,追求能用就行了.

那怎麼構建這個 char str[5] 呢. 這裡原本採用 5層for,這直接pass了,首先一條準則, C程式開發一定要記住,或者程式員也要記住

1 /*
2   用不用goto取決你的業務複雜度
3  
4  */
5 
6 // 但是你一定不要用 超過三層的 迴圈,那種代碼寫出來後要打自己臉.

.後面採用 遞歸搞了一下, 如下

//採用遞歸演算法窮舉
void 
dgaa(char str[],int len,int idx, int *psum, int *pcut)
{
    if (len > idx) {
        str[idx] = 'a';
        dgaa(str, len, idx + 1, psum, pcut);

        str[idx] = 'b';
        dgaa(str, len, idx + 1, psum, pcut);

        str[idx] = 'c';
        return dgaa(str, len, idx + 1, psum, pcut);
    }
    ++*psum;
    *pcut += isaa(str, len);
}

最後需要 return,因為到這裡就結束了,不能再往下了,否則重覆計數了. 大家有好方法可以分享.

到這裡一切都準備妥當了. 完整代碼如下:

#include <stdio.h>
#include <stdlib.h>
#include <stdbool.h>

// 串檢測函數
bool isaa(char str[], int len);

//採用遞歸演算法窮舉
void dgaa(char str[], int len, int idx, int *psum, int *pcut);

/*
 上面函數的簡化巨集, 這裡 用法是
 int psum = 0, pcut = 0;
 char str[5];
 int cut = DGAA(str);
 */
#define DGAA(str, sum, cut) \
    dgaa(str, sizeof(str)/sizeof(*str), 0, &sum, &cut)

/*
 * 這裡處理一個問題
 *  一個由abc組成的五位字元串,至少包含 一個連續aa的串有多少個.
 *
 */
int main(int argc, char* argv[])
{
    int sum = 0, cut = 0;
    char str[5];
    DGAA(str, sum, cut);

    printf("所要找的所有串:%d個, 至少出現一次aa的串有 %d 個!\n",sum, cut);

    return 0;
}

// 串檢測函數
bool 
isaa(char str[], int len)
{
    int i = 0;
    while(++i < len)
        if (str[i] == 'a' && str[i - 1] == 'a') 
            return true;

    return false;
}

//採用遞歸演算法窮舉
void
dgaa(char str[],int len,int idx, int *psum, int *pcut)
{
    if (len > idx) {
        str[idx] = 'a';
        dgaa(str, len, idx + 1, psum, pcut);

        str[idx] = 'b';
        dgaa(str, len, idx + 1, psum, pcut);

        str[idx] = 'c';
        return dgaa(str, len, idx + 1, psum, pcut);
    }
    ++*psum;
    *pcut += isaa(str, len);
}

我們直接編譯鏈接一下

gcc -g -Wall -o aa.out aa.c

總的運行結果如下:

答案是 至少出現一次aa的串有 79 個.

 

第二部分 從更高觀點上分析這個問題

  採用思路就是簡單的數學集合分析.

1) . abc 組成 長度為 5的串

    一共有 3^5 = 81 x 3 = 243

2) . 沒有出現過 aa連續的串個數

  A) 串中沒有a

    2^5 = 32

  B) 串中只有一個a

    首先剩下4個位置 2^4 = 16 後面 一個a 插入 到    x|x |x |x |x 

    x的位置 有 C(1,5) = 5種,一共有 16 x 5 = 80種

  C) 串中有兩個a  x | x | x | x 左邊x的位置選出2個 插入 aa

    一共有 2^3 x C(4,2) = 8 x 4 x 3 / 2 = 48種

  D) 串中有3個 a  就是這樣情況 a | a | a

    只有 2^2 = 4四種情況

  綜上 A,B,C,D 一共有 32 + 80 + 48 + 4 = 112 + 52 = 164種

綜上1) 2) 得到至少一個aa連續出現的5位串 個數為

  243 - 164 = 79 種

問題已經解決. 歡迎大家給出更巧妙的方法分享.

 

後記

   到這裡說結束了, 錯誤是難免的,提出來一定改. 祝今天大家包括自己愉快, 以後的生活多一點行動,少一點

猶豫,關鍵是開心就好.O(∩_∩)O哈哈~


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

-Advertisement-
Play Games
更多相關文章
  • 1.Redis安裝 redis的安裝非常的簡單,而且Redis並不依賴其他環境和標準庫,很容易上手,這可能也是它流行的一個原因。這裡為了測試方便,用的都是windows 環境下測試。下載Windows版本Redis。 redis.windows.conf 是redis的配置文件。 ...
  • 對於一些圖片多,頁面長的網頁來說,如果每次打開頁面載入全部的網頁內容,頁面載入速度勢必會受到影響,如果每次打開網頁只將網頁可視區域的內容載入給用戶 ,將大大提高網頁瀏覽速度,同時也減輕伺服器負載,我們可以使用lazyload.js來實現對圖片的延遲載入,當網頁圖片進入到瀏覽器可視區域時,才會去請求服...
  • 話說是這樣的,這兩天開發一個簡訊發送功能,客戶給了一個 Web Service 地址(沒有文檔),讓我調用就可以發送了,我在VS 2013添加了服務引用,一切正常,可是執行代理方法時,怎麼都報錯RPC Message receiveExtMTPushRequest1 in operation rec...
  • 訂單管理是ERP系統中一個重要模塊,客戶下訂單,ERP通過訂單來為客戶進行配送。訂單模塊主要包括訂單創建,訂單修改,訂單審核,訂單取消,訂單分配,訂單列印,訂單揀貨,訂單出庫。在隨後的幾節里我們看看這些每個模塊是怎麼設計運行的。 1.訂單創建 訂單創建主要功能是下單,下單的時候輸入收貨人信息,...
  • Qt 是目前最先進、最完整的跨平臺C++開發工具。它不僅完全實現了一次編寫,所有平臺無差別運行,更提供了幾乎所有開發過程中需要用到的工具。如今,Qt已被運用於超過70個行業、數千家企業,支持數百萬設備及應用。
  • 要想將 TextBlock 里的文本自動換行的話,只需要設置 TextWrapping 屬性為 Wrap 即可。但是 TextWrapping 是儘可能根據空白字元來換行的,因此,就有可能出現下麵這種狀況:每一行的尾部會出現長短不一的空白。在 UI 設計上,有一點建議,那就是同一級的內容是要對齊的。...
  • 使用PHP的array_unique()函數允許你傳遞一個數組,然後移除重覆的值,返回一個擁有唯一值的數組。這個函數大多數情況下都能工作得很好。但是,如果你嘗試在一個大的數組裡使用array_unique()函數,它會運行地慢一些。 有一個比較好而且更快的函數array_flip()來替代使用ar...
  • Ruby對象數組的排序作者剛剛接觸Ruby,因之前總認為腳本語言語法不規範,對腳本語言有些偏見,如不是項目需要並不會去學習PYTHON、RUBY等語言。現在項目中需要實現對象數組排序的任務,對於昨天開始看ruby的我來說壓力山大啊!【汗】但是經過一番查詢資料,終於初步實現了自己想要的結果,現將自己做...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...