十年網(wǎng)站開發(fā)經(jīng)驗 + 多家企業(yè)客戶 + 靠譜的建站團隊
量身定制 + 運營維護+專業(yè)推廣+無憂售后,網(wǎng)站問題一站解決
感覺你的基本概念不清楚,建議你從頭認真看下JAVA的一些基本概念。
公司主營業(yè)務:成都網(wǎng)站設計、成都網(wǎng)站建設、移動網(wǎng)站開發(fā)等業(yè)務。幫助企業(yè)客戶真正實現(xiàn)互聯(lián)網(wǎng)宣傳,提高企業(yè)的競爭能力。創(chuàng)新互聯(lián)是一支青春激揚、勤奮敬業(yè)、活力青春激揚、勤奮敬業(yè)、活力澎湃、和諧高效的團隊。公司秉承以“開放、自由、嚴謹、自律”為核心的企業(yè)文化,感謝他們對我們的高要求,感謝他們從不同領域給我們帶來的挑戰(zhàn),讓我們激情的團隊有機會用頭腦與智慧不斷的給客戶帶來驚喜。創(chuàng)新互聯(lián)推出東城免費做網(wǎng)站回饋大家。
針對你提的問題解答如下:
calc(int n)是一個方法
System.out.println("10的階乘為:"+calc(10)); 中的calc(10)表示調(diào)用calc方法,同時將10傳遞給方法的形參n,這樣n=10(這個表示等于,相當于程序中的==,下同).
而在calc()方法內(nèi)部,是說如果n=1,方法就返回結(jié)果1,如果不等于就返回n * calc(n-1)。而這個時候的calc(n-1)又再一次調(diào)用calc方法,同時將n-1傳遞給方法的形參n,這樣n=9
如此循環(huán)調(diào)用,直到最后一次n=1時方法直接返回1.
所以calc()方法求的是n的階乘,也就是n*(n-1)*(n-2)*...*2*1
代碼如下:
import java.util.ArrayList;
import java.util.List;
class Org {
private String id;
private String name;
private String pid;
public Org(String id, String name, String pid) {
this.id = id;
this.name = name;
this.pid = pid;
}
public String getId() {
return id;
}
public void setId(String id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public String getPid() {
return pid;
}
public void setPid(String pid) {
this.pid = pid;
}
@Override
public String toString() {
return "Org [id=" + id + ", name=" + name + ", pid=" + pid + "]";
}
}
public class App {
static void find(ListOrg list, String pid) {
list.stream().filter(p - p.getPid().equals(pid))
.forEach(org - {
System.out.println(org);
find(list, org.getId());
});
}
public static void main(String[] args) {
ListOrg list = new ArrayList();
list.add(new Org("111", "公司", "0"));
list.add(new Org("222", "部門", "111"));
list.add(new Org("333", "小組", "222"));
list.add(new Org("444", "員工1", "333"));
list.add(new Org("555", "員工2", "333"));
find(list, "0");
System.out.println("------------------------------------");
find(list, "111");
}
}
運行結(jié)果:
下面遞歸寫了一段遞歸累加到100,每加20個就換行輸出。
package?zhidao;
public?class?Digui?{
public?static?int?add(int?num){
int?sum?=?0;
StringBuffer?sb?=?new?StringBuffer();
if?(num?=?0)?{
return?0;
}else{
if?(num?==?1)?{
sum?=?sum+1;
}else?{
sum?=?add(num-1)+num;
}
if?(num?%?20?==?0)?{
System.out.println("[index?=?"+num+"?sum?=?"+sum+"]");
}else?{
System.out.print("[index?=?"+num+"?sum?=?"+sum+"],");
}
}
return?sum;
}
public?static?void?main(String[]?args)?{
add(100);
}
}
遞歸是自己調(diào)用自己,下面給個例子
public static void main(String args[])
{
System.out.println(sum(100));
}
public static int sum(int num)//遞歸調(diào)用的方法
{
if(num==1)
{
return 1 ;
}else{
return num + sum(num-1) ;//這里遞歸調(diào)用了阿
}
}