李洋瘋狂C語言之用遞歸解決李白喝酒問題(二)

之前用遞歸求出了多少種情況,如果要打印出所有的結果,就需要一個數組來存放可能的情況:

/******************************************************
題目:“李白街上走,提壺去買酒,遇店加一倍,見花喝一斗”,
途中,遇見5次店,見了10此花,壺中原有2斗酒,最后剛好喝
完酒,要求最后遇見的是花,求可能的情況有多少種?原理:起點位置店和花都為0,酒為2。遇到一次店,酒*2。遇
到一次花,酒-1,當5次店和9次花都遇完,酒為1。遞歸終止條
件為,店和花超過題中所給或滿足題目要求。
*******************************************************/#include <stdio.h>int count = 0;//pre為 1 時代表碰到店,為 0 時代表碰到花,確保最后一次是花
void fun(int store, int flower, int alco, int pre, char* ch, int index)
{//遞歸 終止條件if (0 == store && 0 == flower){if (0 == alco && 0 == pre){int i = 0;for (i = 0; i < 15; i++)    //輸出可能的組合{printf ("%c", ch[i]);}putchar ('\n');count++;}return ;}//終止條件結束if (0 < store){ch[index] = 'a';                //a代表碰到的是店  fun(store - 1, flower, alco * 2, 1, ch, index + 1);}if (0 < flower){ch[index] = 'b';                //b代表碰到的是花fun(store, flower - 1, alco - 1, 0, ch, index + 1);}
}int main()
{   char ch[20];                        //定義一個數組用以存放可能的情況fun(5, 10, 2, -1, ch, 0);           //pre賦初值-1printf ("共有 %d 種可能\n", count);return 0;
}

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/448574.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/448574.shtml
英文地址,請注明出處:http://en.pswp.cn/news/448574.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

vue.js 三種方式安裝 ( vue-cli ) 、安裝詳解、創建項目

前些天發現了一個巨牛的人工智能學習網站&#xff0c;通俗易懂&#xff0c;風趣幽默&#xff0c;忍不住分享一下給大家。點擊跳轉到教程。 Vue.js&#xff08;讀音 /vju?/, 類似于 view&#xff09;是一個構建數據驅動的 web 界面的漸進式框架。Vue.js 的目標是通過盡可能簡單…

C學習筆記:基礎

C 語言是一種面向過程的高級語言。 運行速度與匯編語言編寫的代碼運行速度幾乎一樣。C 語言的源碼文件擴展名為 .c 例如 hello.c 。 概述 C 語言有三套標準分別是 C89 C99 C11&#xff0c;目前最常用的是 C99 標準。 C 編譯器&#xff0c;寫在源文件中的源代碼需要編譯&#xf…

spring-boot

1,創建springboot 工程 2.導入你所需要的包, (這篇只是簡單介紹一下,沒導入太過復雜的包)Developer tools Sprig Boot DevTools LombokWed Spring Wed Starter 轉載于:https://www.cnblogs.com/lxx-1843693653/p/11104622.html

李洋瘋狂C語言之合法幀

題目: 輸入一個字符串,同時輸入幀頭和幀尾(可以是多個字符),將該字符串中合法的幀識別出來. 提示:幀頭和幀尾分別是head和tail 字符串”asdheadhauboisoktail”中headhauboisoktail是合法幀 #include <stdio.h> #include <string.h> #include <stdlib.h>ch…

vuex 最簡單、最詳細的入門文檔

前些天發現了一個巨牛的人工智能學習網站&#xff0c;通俗易懂&#xff0c;風趣幽默&#xff0c;忍不住分享一下給大家。點擊跳轉到教程。 如果你在使用 vue.js , 那么我想你可能會對 vue 組件之間的通信感到崩潰 。 我在使用基于 vue.js 2.0 的UI框架 ElementUI 開發網站的時…

科目三路考操作要點

一踏&#xff08;離合器&#xff09;二掛&#xff08;擋&#xff09;三撥&#xff08;左轉向燈&#xff09;四看&#xff08;左右鏡及側頭觀察周邊情況&#xff09;五按&#xff08;喇叭&#xff09;六松&#xff08;閘&#xff0c;即手制動&#xff09; 在科目三考試途中的注…

10種頂級javascript框架比較-The Top 10 Javascript MVC Frameworks

轉載于&#xff1a;http://codebrief.com/2012/01/the-top-10-javascript-mvc-frameworks-reviewed/ Gordon L. Hempton是西雅圖的一位黑客和設計師&#xff0c;他花費了幾個月的時間研究和比較了12種流行的JavaScript MVC框架&#xff0c;并在博客中總結了每種框架的優缺點&am…

數據結構之順序表(一)

有關順序表&#xff0c;由于代碼太長&#xff0c;我將分成2部分&#xff0c;這邊是頭文件SeqList.h和主函數&#xff1a; #ifndef __SEQLIST_H__ #define __SEQLIST_H__#define FALSE -1 #define TRUE 0#define INIT_SIZE 100 #define INCRESS_SIZE 20typedef int Seq…

centos7 安裝 node.js 運行環境、卸載

前些天發現了一個巨牛的人工智能學習網站&#xff0c;通俗易懂&#xff0c;風趣幽默&#xff0c;忍不住分享一下給大家。點擊跳轉到教程。 一.安裝 1.進入官網下載最新版本 https://nodejs.org/en/ 選擇下載后上傳或直接使用wget下載 wget https://nodejs.org/dist/v8.11.…

白云山腳下的廉價菜-飲勝酒家

亞運將至&#xff0c;我們已經漸漸感受到那種氣氛了&#xff0c;最明顯就是搭公交車不用錢&#xff0c;我可以不再做那輛兜路的54路車&#xff0c;每天可以睡多10分鐘&#xff0c;然后從家樓下轉3趟車上班&#xff0c;重要部部都有位置坐&#xff0c;每天在路上都看到有好多好多…

科目三考試指南

正在準備科目三的您&#xff0c;對順利通過考試有信心嗎&#xff1f;今天&#xff0c;小編為大家帶來科目三靠邊停車技巧&#xff0c;通過講解靠邊停車考試要求&#xff0c;讓學員更好地掌握相關技巧&#xff0c;希望能幫到大家。 靠邊停車考試項目中規定&#xff0c;車前保險杠…

docker學習4-docker安裝mysql環境

前言 docker安裝mysql環境非常方便&#xff0c;簡單的幾步操作就可以了 拉取mysql鏡像 先拉取mysql的鏡像&#xff0c;可以在docker的鏡像倉庫找到不同TAG標簽的版本https://hub.docker.com/_/mysql?tabtags 我這里選擇mysql:5.7標簽 [rootyoyo ~]# docker pull mysql:5.7 5.7…

數據結構之順序表(二)

這是接著之前的剩下來的部分&#xff1a; #include <stdlib.h> #include "SeqList.h" #include <stdio.h>SeqList *Create_List() {//創建一個順序表SeqList* s (SeqList*)malloc(sizeof(SeqList)/sizeof(char));if (NULL s){return NULL;}//初始化順…

Dynamics CRM 2015 站點地圖公告配置實體顯示名稱的變更

CRM更新2015后&#xff0c;在設置里找不到公告配置了 在原來的位置上你會東西一個叫活動源配置的東西&#xff0c;點開看后就是原來的公告配置。 版權聲明&#xff1a;本文為博主原創文章&#xff0c;未經博主允許不得轉載。 轉載于:https://www.cnblogs.com/VicTang/p/4799531…

解決:liunx 光標消失(顯示光標)

前些天發現了一個巨牛的人工智能學習網站&#xff0c;通俗易懂&#xff0c;風趣幽默&#xff0c;忍不住分享一下給大家。點擊跳轉到教程。 2個命令可以管控光標&#xff1a; 隱藏光標 &#xff1a; echo -e "\033[?25l" 顯示光標 &#xff1a; echo -e "\0…

科?目?三?路?考?操?作?步?驟

科目三路考操作步驟 一、起步前五大操作順序&#xff1a; 1.檢查手制動是否拉緊 2.踩下離合器踏板&#xff0c;掛空擋 3.開汽車電源 4.輕踩油門&#xff08;電噴車不需要&#xff09;&#xff0c;接通馬達 5.發動后&#xff0c;手馬上離開 二、起步順序6個步驟&…

漫談微服務架構:什么是Spring Cloud,為何要選擇Spring Cloud

Spring Cloud是基于Spring Boot的&#xff0c;因此還在使用SpringMVC的同學要先了解Spring Boot。先上一段官話&#xff0c;Spring Cloud是一個基于Spring Boot實現的云應用開發工具&#xff0c;它為基于JVM的云應用開發中涉及的配置管理、服務發現、斷路器、智能路由、微代理、…

數據結構之頭指針鏈表de三種插入方式(頭插法,尾插法,在pos處插入)

1、頭插法&#xff1a; 流程&#xff1a;1 &#xff0c;判斷傳入數據是否正確 2&#xff0c;如果正確則創建一個新的節點&#xff0c;并判斷節點是否創建成功 3&#xff0c;然后給節點成員變量賦值 4&#xff0c;最后讓新節點變為鏈表的第一個節點。 代碼實現: // 鏈表的頭插…

c# 科學計數法值轉換成正常值,返回字符串

/// <summary>/// 科學計數法值轉換成正常值/// </summary>/// <param name"value"></param>/// <returns></returns>public string ValueScientificNotationConvert(JToken value){if (value null) return "";var …

使用 Docker 部署 Node 服務

前些天發現了一個巨牛的人工智能學習網站&#xff0c;通俗易懂&#xff0c;風趣幽默&#xff0c;忍不住分享一下給大家。點擊跳轉到教程。 前言   Docker 是一個開源的容器引擎。開發者可以將自己的應用以及依賴打包為一個可移植的容器&#xff0c;然后發布到 Linux 機器上。…