day23-遞歸練習(xí)/集合練習(xí)

23.01_File類遞歸練習(xí)(統(tǒng)計(jì)該文件夾大小)

  • 需求:1,從鍵盤接收一個(gè)文件夾路徑,統(tǒng)計(jì)該文件夾大小
/**
 * 統(tǒng)計(jì)文件夾大小
 */
public static long getFileLength(File file) {
    long length = 0;
    for (File f : file.listFiles()) {
        if (f.isFile()) {
            length += f.length();
        }else {  //文件夾就遞歸
            length += getFileLength(f);  
        }
    }
    return length ;
}

/**
 * 鍵盤錄入文件夾路徑
 * @return 文件夾路徑
 */
public static File getDir() {
    Scanner sc = new Scanner(System.in);
    System.out.println("請輸入文件夾路徑...");
    
    while(true) {
        File file = new File(sc.nextLine());
        if (!file.exists()) {  //是否存在路徑或文件
            System.out.println("路徑不存在,請重新輸入...");
            continue;
        } else if(file.isFile()) { //是文件篓足,就以當(dāng)前文件所在文件夾為目標(biāo)文件夾
            sc.close();
            return file.getParentFile();
        } else {
            sc.close();
            return file ;
        }
    }
}

long size = getFileLength(getDir());
float t = (float) (size / 1024.0 / 1024.0 / 1024.0);
DecimalFormat df = new DecimalFormat("#.##");    //四舍五入保留小數(shù)
System.out.println("文件夾大小是: " + df.format(t) + "GB");
System.out.println("文件夾大小是: " + t + "字節(jié)");

23.02_File類遞歸練習(xí)(刪除該文件夾)

  • 需求:2,從鍵盤接收一個(gè)文件夾路徑,刪除該文件夾
/**
 * 刪除文件夾
 * @param file 文件夾路徑
 */
public static void deleteFile(File file) {
    for (File f : file.listFiles()) {  //如果文件夾不是空的段誊,那么delete()是刪不掉的,
        if (f.isFile()) {
            f.delete();  //文件就直接刪除
        } else {
            deleteFile(f);  //遞歸刪除文件夾子內(nèi)容
        }
    }
    file.delete();
}

23.03_File類遞歸練習(xí)(拷貝)

  • 需求:3,從鍵盤接收兩個(gè)文件夾路徑,把其中一個(gè)文件夾中(包含內(nèi)容)拷貝到另一個(gè)文件夾中
/**
 * 將path1文件內(nèi)的子內(nèi)容拷貝到path2文件夾內(nèi)
 * @param initPath 源文件夾路徑
 * @param path1 源文件夾路徑
 * @param path2 目標(biāo)文件夾
 * @throws IOException
 */
public static void copyFile(String initPath, File path1, File path2) throws IOException {
    if (path1.equals(path2)) return ; //防止相同文件夾造成死循環(huán)
    
    for (File subFile : path1.listFiles()) {
        if (subFile.isFile()) {  // 是否文件直接拷貝
            // 處理路徑問題栈拖,拷貝過去枕扫,要求層級目錄不變
            String path = subFile.getPath();
            String sp = path.substring(initPath.length()); //得到文件的層級結(jié)構(gòu)
            File newDir = new File(path2.getPath() + sp).getParentFile();
            if (!newDir.exists()) {  //在新文件夾下,建立層級結(jié)構(gòu)
                newDir.mkdirs();
            }
            FileInputStream fis = new FileInputStream(subFile);
            FileOutputStream fos = new FileOutputStream(path2.getPath() + sp);
            
            byte[] data = new byte[1024 * 10];
            int len ;
            while( (len = fis.read(data)) != -1) {
                fos.write(data, 0, len);
            }
            
            fis.close();
            fos.close();
        } else {  // 文件夾就遞歸
            copyFile(initPath, subFile, path2);
        }
    }
}

23.04_File類遞歸練習(xí)(按層級打印)

  • 需求:4,從鍵盤接收一個(gè)文件夾路徑,把文件夾中的所有文件以及文件夾的名字按層級打印
/**
 * 按層級結(jié)構(gòu)打印文件夾目錄
 * @param file 文件夾路徑
 * @param lev 遞歸計(jì)數(shù)器辱魁,調(diào)用時(shí)烟瞧,必須傳入0
 */
public static void printFile(File file , int lev) {
    for ( File subFile : file.listFiles() ) {
        
        for(int i = 0 ; i < lev ; i++) { //打印層級結(jié)構(gòu)诗鸭,這種思路很巧妙
            System.out.print("\t");
        }
        System.out.println(subFile); //無論是文件還是文件夾,都需要直接打印
        
        if (subFile.isDirectory()) {  //是文件夾就遞歸
            printFile(subFile, lev+1); //這里不能 ++ 運(yùn)算符参滴,思考一下為什么
        }
    }
}

23.05_遞歸練習(xí)(斐波那契數(shù)列)

  • 不死神兔
    故事得從西元1202年說起强岸,話說有一位意大利青年,名叫斐波那契砾赔。在他的一部著作中提出了一個(gè)有趣的問題:假設(shè)一對剛出生的小兔一個(gè)月后就能長成大兔蝌箍,再過一個(gè)月就能生下一對小兔,并且此后每個(gè)月都生一對小兔暴心,一年內(nèi)沒有發(fā)生死亡妓盲,
  • 問:一對剛出生的兔子,一年內(nèi)繁殖成多少對兔子?
  • 兔子數(shù)量增長數(shù)列: 1 1 2 3 5 8 13...
// 方法二: 遞歸解決
public static int fun(int mou) {  // mou為任意月份专普,返回此月份的兔子數(shù)量
    if (mou == 1 || mou == 2) {
        return 1 ;
    }
    return fun(mou - 2) + fun(mou - 1) ;
}

// 方法一: 數(shù)組解決
public static void demo1() {
    int[] arr = new int[12];  //長度就是多少個(gè)月份
    arr[0] = 1;  //根據(jù)數(shù)列規(guī)律悯衬,前2個(gè)數(shù)的和就是第三個(gè)的數(shù),而前2個(gè)數(shù)確定是1
    arr[1] = 1;
    
    // 遍歷數(shù)組檀夹,對其他月份賦值
    for (int i = 2; i < arr.length; i++) {
        arr[i] = arr[i-1] + arr[i-2]; 
    }
    
    System.out.println(arr[12]);
}

23.06_遞歸練習(xí)(1000的階乘所有零和尾部零的個(gè)數(shù))

  • 需求:求出1000的階乘所有零和尾部零的個(gè)數(shù),不用遞歸做
BigInteger bi1 = new BigInteger("1");
for(int i = 1 ; i <= 1000 ; i++) {
    BigInteger bi2 = new BigInteger(i+"");
    bi1 = bi1.multiply(bi2); //將 bi1 和 bi2的結(jié)果相乘再賦值給bi1
}
String str = bi1.toString();
int count = 0 ;
for (char c : str.toCharArray()) {
    if ('0' == c) count++ ;
}
System.out.println("所有零的個(gè)數(shù):" + count);

// 字符串反轉(zhuǎn) (鏈?zhǔn)骄幊?筋粗,最好記住下面的方法
str = new StringBuilder(str).reverse().toString();
int num= 0 ;
for(char c : str.toCharArray()) {
    if('0' != c) break ;
    num++;
}
System.out.println("尾部零的個(gè)數(shù):" + num);

23.07_遞歸練習(xí)(1000的階乘尾部零的個(gè)數(shù))

  • 需求:求出1000的階乘尾部零的個(gè)數(shù),用遞歸做
public static int fun(int num) {
    if (num > 0 && num < 5) {
        return 0;
    } else {
        return num / 5 + fun(num / 5);
    }
}
// 推導(dǎo)過程十分麻煩,百度吧炸渡,比如下面鏈接的講解
http://blog.csdn.net/yahohi/article/details/7528803

23.08_集合練習(xí)(約瑟夫環(huán))

  • 幸運(yùn)數(shù)字
/**
 * 約瑟夫環(huán)娜亿,幸運(yùn)數(shù)字
 * @param num 人數(shù),多少人進(jìn)約瑟夫環(huán)游戲
 * @return 最后那個(gè)幸運(yùn)的人的位置
 */
public static int getLuckNum(int num) {
    ArrayList<Integer> list = new ArrayList<>();  
    for (int i = 1; i <= num; i++) { //將1...num個(gè)元素存儲到集合里
        list.add(i);
    }
    
    int count = 1 ;  //用來數(shù)數(shù)蚌堵,計(jì)算器买决,只要是3的倍數(shù)就殺人
    for(int i = 0; list.size() != 1 ; i++) {  //只要集合人數(shù)不是1,就循環(huán)殺人
        if (i == list.size()) i = 0 ; //到數(shù)組末尾吼畏,就重新從頭開始遍歷
        if (count % 3 == 0) list.remove(i--);  //如果是3的倍數(shù)策州,就殺人。,--是因?yàn)閿?shù)組元素減少了宫仗,索引也要跟著減少
        count++;
    }
    return list.get(0);
}

END够挂。
我是小侯爺。
在魔都艱苦奮斗藕夫,白天是上班族孽糖,晚上是知識服務(wù)工作者。
如果讀完覺得有收獲的話毅贮,記得關(guān)注和點(diǎn)贊哦办悟。
非要打賞的話,我也是不會拒絕的滩褥。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末病蛉,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌铺然,老刑警劉巖俗孝,帶你破解...
    沈念sama閱讀 222,865評論 6 518
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異魄健,居然都是意外死亡赋铝,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 95,296評論 3 399
  • 文/潘曉璐 我一進(jìn)店門沽瘦,熙熙樓的掌柜王于貴愁眉苦臉地迎上來革骨,“玉大人,你說我怎么就攤上這事析恋×颊埽” “怎么了?”我有些...
    開封第一講書人閱讀 169,631評論 0 364
  • 文/不壞的土叔 我叫張陵助隧,是天一觀的道長筑凫。 經(jīng)常有香客問我,道長喇颁,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 60,199評論 1 300
  • 正文 為了忘掉前任嚎货,我火速辦了婚禮橘霎,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘殖属。我一直安慰自己姐叁,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 69,196評論 6 398
  • 文/花漫 我一把揭開白布洗显。 她就那樣靜靜地躺著外潜,像睡著了一般。 火紅的嫁衣襯著肌膚如雪挠唆。 梳的紋絲不亂的頭發(fā)上处窥,一...
    開封第一講書人閱讀 52,793評論 1 314
  • 那天,我揣著相機(jī)與錄音玄组,去河邊找鬼滔驾。 笑死,一個(gè)胖子當(dāng)著我的面吹牛俄讹,可吹牛的內(nèi)容都是我干的哆致。 我是一名探鬼主播,決...
    沈念sama閱讀 41,221評論 3 423
  • 文/蒼蘭香墨 我猛地睜開眼患膛,長吁一口氣:“原來是場噩夢啊……” “哼摊阀!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 40,174評論 0 277
  • 序言:老撾萬榮一對情侶失蹤胞此,失蹤者是張志新(化名)和其女友劉穎臣咖,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體豌鹤,經(jīng)...
    沈念sama閱讀 46,699評論 1 320
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡亡哄,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,770評論 3 343
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了布疙。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片蚊惯。...
    茶點(diǎn)故事閱讀 40,918評論 1 353
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖灵临,靈堂內(nèi)的尸體忽然破棺而出截型,到底是詐尸還是另有隱情,我是刑警寧澤儒溉,帶...
    沈念sama閱讀 36,573評論 5 351
  • 正文 年R本政府宣布宦焦,位于F島的核電站,受9級特大地震影響顿涣,放射性物質(zhì)發(fā)生泄漏波闹。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 42,255評論 3 336
  • 文/蒙蒙 一涛碑、第九天 我趴在偏房一處隱蔽的房頂上張望精堕。 院中可真熱鬧,春花似錦蒲障、人聲如沸歹篓。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,749評論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽庄撮。三九已至,卻和暖如春毙籽,著一層夾襖步出監(jiān)牢的瞬間洞斯,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,862評論 1 274
  • 我被黑心中介騙來泰國打工坑赡, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留巡扇,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 49,364評論 3 379
  • 正文 我出身青樓垮衷,卻偏偏與公主長得像厅翔,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個(gè)殘疾皇子搀突,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,926評論 2 361

推薦閱讀更多精彩內(nèi)容

  • Android 自定義View的各種姿勢1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 172,336評論 25 707
  • Ubuntu的發(fā)音 Ubuntu顽分,源于非洲祖魯人和科薩人的語言,發(fā)作 oo-boon-too 的音施蜜。了解發(fā)音是有意...
    螢火蟲de夢閱讀 99,373評論 9 467
  • 1 IONo18 1.1IO框架 【 IO:Input Output 在程序運(yùn)行的過程中卒蘸,可能需要對一些設(shè)備進(jìn)...
    征程_Journey閱讀 966評論 0 1
  • 初中開始,就對省外的世界充滿幻想翻默。大概覺得自己與眾不同缸沃,別人不愿意去的地方偏要走一遭,不愿意走的路硬是要踩一遍修械。高...
    鬼扯少女閱讀 284評論 1 3
  • 天沐王朝京都繁華熱鬧趾牧,街面商鋪林立,往來人群不斷肯污,你走在大街上隨手拉過一人翘单,問他可知道京都四美?那人定能頭頭事道...
    山水葉子閱讀 169評論 0 0