課程作業1

1使用組合數公式利用n!來計算

a.設計思想

定義n和k,用遞歸函數表示出N!的階乘結果,c(n,k)=n!/(k!(n-k)!);調用函數求出c(n,k)的結果

b.源代碼

package kecheng1;
import java.util.Scanner;
public class Test
{public static void main(String[] args) {System.out.print("請輸入N:");Scanner s=new Scanner(System.in);int n=s.nextInt();System.out.print("請輸入:k") ;int k=s.nextInt();System.out.println(n+"!="+ca(n));double x=ca(n)/(ca(k)*ca(n-k));System.out.println(x);}public static long ca(int n) {if(n==1 || n==0){return 1;}return n*ca(n-1);}//遞歸函數
}

c.流程圖

d.結果截圖

2.使用遞推的方法用楊輝三角形計算

a.程序設計思想

利用遞推的方法和楊輝三角計算出組合數的結果,將輸入的變量NK表示為楊輝三角的行和列,利用二位數組具體求出楊輝三角的數值,最后輸出需要的組合數的數值

b.源代碼

package kechengab;import java.util.Scanner;
public class Dituiyh 
{public static void main(String[] args){Scanner put=new Scanner(System.in);System.out.println("輸入行:");int x=put.nextInt();System.out.println("輸入列:");int y=put.nextInt();if(y>x)System.out.print("輸入的數據錯誤");int [][]a=new int[6][6];for(int i=0;i<=x;i++){for(int s=0;s<=i;s++){if(s==i||s==0)a[i][s]=1;else{a[i][s]=a[i-1][s-1]+a[i-1][s];}}}//利用二維數組楊輝三角的表示System.out.println("組合數c(x,y)的值為"+a[x][y]);//輸出要求的值
    }}

c.程序流程圖

d.結果截圖

3.漢諾塔

a.程序設計思想

調用遞歸函數,終止條件為參數N=1;移動盤子時,利用兩個函數,將盤子移動,利用中間的b柱子作為跳板,遞歸函數求出具體步驟,引用另一個函數具體輸出盤子移動的步驟

b.程序源代碼

package hannuota;
import java.util.Scanner;
public class Peg 
{static private int n = 0;public static void main(String[] args) {Scanner in = new Scanner(System.in);char one = 'A';char three = 'B';char  two= 'C';System.out.println("輸入盤子數");int num = in.nextInt();  hanni(num,one,three,two);in.close();}private static void move(int num,char start,char end){n=n+1;System.out.println(n+"步操作盤子從:"+start+"-->"+end);}//函數表示出具體的盤子移動的方法private static void hanni(int num,char one,char three,char two) {if(num==1){move(1,one,two);}else{hanni(num-1,one,three,two);move(num,one,two);                 hanni(num-1,three,one,two);}}//遞歸的方法求出盤子移動軌跡}

c.流程圖

d結果截圖

4.回文數

a程序設計思想

定義字符串儲存想要的驗證的字符串,定義一個數組儲存,將兩個數組首尾進行比較,結束條件為比較到數組的中值處

b.源代碼

package huiwen;import java.util.Scanner;public class Dihuiwen
{public static void main(String[] args) {Scanner put =new Scanner(System.in);System.out.println("輸入字符串:");String a = put.nextLine();//定義字符串char[] ch = new char[a.length()];for(int i = 0;i<a.length();i++){ch[i] = a.charAt(i);}//將字符穿賦值給數組if(zifu(ch,ch.length)==0)//引用函數體
        {System.out.println("該字符串不是回文!");}else{System.out.println("該字符串是回文!");}//
        put.close(); }private static int zifu(char[] c,int i) {int size = c.length;if(i == size/2){return 1;}if(c[size - i] == c[i-1]){return zifu(c,i-1);}elsereturn 0;} //遞歸函數判斷字符串是否為回文數
}

c.流程圖

d.結果截圖

?

?總結

該課程主要練習了遞歸函數以及隨機數的運用,雖然完成了部分課題,但是自我感覺對于隨機數的運用,以及對于遞歸函數掌握還沒有到達非常熟練的地步,在以后的練習中,自己還需要對這兩方面內容進行更加全面的認識以及掌握。

?

轉載于:https://www.cnblogs.com/xuzhaoyang/p/7663877.html

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

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

相關文章

新手學Python推薦的四本書籍+2個資源網站

2019獨角獸企業重金招聘Python工程師標準>>> 很多伙伴初學Python&#xff0c;會問到&#xff1a;有沒有好的學習書籍推薦&#xff1f;有沒有好的學習網站推薦&#xff1f; 針對這類伙伴的問題&#xff0c;小優給大家整理了學習Python的四本書籍2個資源網站&#xff…

【轉】Linux系統編程---dup和dup2詳解

正常的文件描述符&#xff1a; 在linux下&#xff0c;通過open打開以文件后&#xff0c;會返回一個文件描述符&#xff0c;文件描述符會指向一個文件表&#xff0c;文件表中的節點指針會指向節點表。看下圖&#xff1a; 打開文件的內核數據結構 dup和dup2兩個函數都可以用來復制…

Android Activity標簽屬性

Android Activity標簽屬性 Activity 是 Android 系統四大應用組件之一&#xff0c;用戶可與 Activity 提供的屏幕進行交互&#xff0c;以執行撥打電話、拍攝照片、發送電子郵件等操作開發者必須在清單文件中聲明要使用的 Activity&#xff0c;這樣系統才能訪問它。聲明方式是在…

Java -----JVM運行時數據區

一、JVM體系結構 想要了解運行時數據區&#xff0c;先關注一下JVM的體系結構&#xff0c;知道數據區在JVM的整體位置和作用。 二、JVM運行時數據區 1.程序計數器 一塊較小的內存空間&#xff0c;它是當前線程所執行的字節碼的行號指示器&#xff0c;字節碼解釋器工作時通過改變…

20155235 《網絡攻防》 實驗八 Web基礎

20155235 《網絡攻防》 實驗八 Web基礎 實驗內容 Web前端HTML(0.5分) 能正常安裝、啟停Apache。理解HTML&#xff0c;理解表單&#xff0c;理解GET與POST方法,編寫一個含有表單的HTML。Web前端javascipt(0.5分) 理解JavaScript的基本功能&#xff0c;理解DOM。編寫JavaScript驗…

python每天1道面試題(3)--字符串組合

""" 題目3&#xff1a;輸入一個字符串&#xff0c;輸出該字符串中字符的所有組合。舉個例子&#xff0c;如果輸入abc&#xff0c;它的組合有a、b、c、ab、ac、bc、abc。解題思路: 先用列舉法,舉例出組合元素長度分別是1,2,..,len(str)時的具體元素, 然后發現當數…

【每周一圖】蜂鳥

攝影/祈澈姑娘小花園偶遇的一只蜂鳥轉載于:https://www.cnblogs.com/wangting888/p/9702088.html

API網關如何實現對服務下線實時感知

上篇文章《Eureka 緩存機制》介紹了Eureka的緩存機制&#xff0c;相信大家對Eureka 有了進一步的了解&#xff0c;本文將詳細介紹API網關如何實現服務下線的實時感知。 一、前言 在基于云的微服務應用中&#xff0c;服務實例的網絡位置都是動態分配的。而且由于自動伸縮、故障和…

TCP為什么要三次握手和四次揮手

http://www.jellythink.com/archives/705 簡析TCP的三次握手與四次分手 https://zhuanlan.zhihu.com/p/24001696 計算機網絡面試題 https://www.zhihu.com/question/36930631 TCP四次分手中&#xff0c;主動關閉方最后為什么要等待2MSL之后才關閉連接&#xff1f; http://ww…

Java處理文件BOM頭的方式推薦

背景&#xff1a; java普通的文件讀取方式對于bom是無法正常識別的。 使用普通的InputStreamReader&#xff0c;如果采用的編碼正確&#xff0c;那么可以獲得正確的字符&#xff0c;但bom仍然附帶在結果中&#xff0c;很容易導致數據處理出錯。另外&#xff0c;對于存在BOM頭的…

封裝svg組件

如何封裝svg圖標組件 封裝svg圖標組件的方法有很多種&#xff0c;如果只是單純的想使用svg圖標&#xff0c;可以將svg導出fonts字體圖標使用&#xff0c;但這樣做會失去svg原有的樣式與尺寸&#xff0c;也可以當成img圖片或者背景引入&#xff0c;但這樣做非常繁瑣。 最近項目中…

RabbitMQ 延遲隊列,消息延遲推送

應用場景 目前常見的應用軟件都有消息的延遲推送的影子&#xff0c;應用也極為廣泛&#xff0c;例如&#xff1a; 淘寶七天自動確認收貨。在我們簽收商品后&#xff0c;物流系統會在七天后延時發送一個消息給支付系統&#xff0c;通知支付系統將款打給商家&#xff0c;這個過程…

windows Navicat Premium連接oracle

需要下載并指定Instant Client 下載地址&#xff1a;在oracle官網搜索Instant Client Downloads選擇自己需要的客戶端 //說明 //Navicat 版本 9 或以上捆綁了 instant client&#xff0c;但是捆綁的用不了&#xff0c;捆綁的10.2。因此下載高版本替換之 //版本有要求&#xff0…

關于arraylist的擴容機制

ArrayList會自動改變size的長度&#xff1a; 首先&#xff0c;ArrayList定義了一個私有的未被序列化的數組elementData&#xff0c;用來存儲ArrayList的對象列表&#xff08;注意只定義未初始&#xff09;&#xff1a;private transient Object[] elementData;   其次&am…

不同級別UI設計師的區別有哪些?

不同等級的UI設計師在工作內容以及基本的薪資待遇方面也是有區別的&#xff0c;很多在UI培訓學校學習的小伙伴們并不知道各個等級的UI設計師工作內容有什么差別&#xff0c;那么合肥學碼思小編就給大家總結一下這些區別分別表現在哪些方面。 一、初級UI設計師 初級UI設計師的主…

Linux命令行參數前加--,-和不加杠

參數前“-”的表明后面的參數是字符形式。參數前“--”的則表明后面的參數是單詞形式。參數前有橫的是System V風格。 參數前沒有橫的是BSD風格。 轉載于:https://www.cnblogs.com/YYRise/p/9090476.html

反射筆記-----------------------------

1.反射基本概念&#xff1a; 01.定義&#xff1a; 反射是指在程序運行期間&#xff0c;能夠觀察和修改類或者類的對象的屬性和行為的特性&#xff01; 02.作用&#xff1a; 001.在運行期間獲取類的修飾符&#xff0c;包名&#xff0c;類名&#xff0c;實現的接口&#xff0c;繼…

kubernetes 集群部署

kubernetes 集群部署 環境JiaoJiao_Centos7-1(152.112) 192.168.152.112JiaoJiao_Centos7-2(152.113) 192.168.152.113JiaoJiao_Centos7-3(152.114) 192.168.152.114已開通 4C8G80G 集群規劃 部署方式 環境準備&#xff1a;基于主機名稱通信&#xff0c;時間同步&#xff0c;關…

PHP學習筆記--抽象類和抽象方法的應用

抽象類** 什么是抽象方法&#xff1f;** 定義&#xff1a;如果一個類中的方法&#xff0c;沒有方法體的方法就是抽象方法(就是一個方法沒有使用{}而直接使用分號結束)* * abstract function test(); //抽象方法* * function test(){ //有方法體…

wordpress 顯示數學公式 (MathJax-LaTeX)

blog 不放一堆數學公式怎么能顯得高大上&#xff0c;所以 MathJax-LaTeX 也是必裝的插件之一了。 一、安裝 MathJax-LaTex 插件 直接在 wordpress 插件中&#xff0c;搜索并安裝 MathJax-LaTeX 二、安裝本地 MathJax 服務 不過由默認的 MathJax cdn 服務經常被墻&#xff0c;所…