Day23_IO第五天
1、递归求5的阶乘
package com.heima.chario;public class Demo8_Digui {/*** @param args* 递归:方法自己调用自己* 5!* 5 * 4 * 3 * 2 * 1** 5 * fun(4)(代表4!)* 4 * fun(3)(代表3!)* 3 * fun(2)(代表2!)* 2 * fun(1)(代表1!)* 递归的弊端:不能调用次数过多,容易导致栈内存溢出* 递归的好处:不用知道循环次数** 构造方法是否可以递归调用?* 构造方法不能使用递归调用** 递归调用是否必须有返回值?* 不一定(可以有,也可以没有)*/public static void main(String[] args) {/*int result = 1;for(int i = 1; i <= 5; i++) {result = result * i;}System.out.println(result);*/System.out.println(fun(6000));}public static int fun(int num) {if(num == 1) {return 1;}else {return num * fun(num - 1);}}}
2、从键盘接收一个文件夹路径,统计该文件夹大小
package com.heima.test;import java.io.File;import java.util.Scanner;public class Test1 {/*** @param args* 需求:1,从键盘接收一个文件夹路径,统计该文件夹大小** 从键盘接收一个文件夹路径* 1,创建键盘录入对象* 2,定义一个无限循环* 3,将键盘录入的结果存储并封装成File对象* 4,对File对象判断* 5,将文件夹路径对象返回** 统计该文件夹大小* 1,定义一个求和变量* 2,获取该文件夹下所有的文件和文件夹listFiles();* 3,遍历数组* 4,判断是文件就计算大小并累加* 5,判断是文件夹,递归调用*/public static void main(String[] args) {//File dir = new File("F:\\day06");//System.out.println(dir.length()); //直接获取文件夹的结果是0File dir = getDir();System.out.println(getFileLength(dir));}/** 从键盘接收一个文件夹路径* 1,返回值类型File* 2,参数列表无*/public static File getDir() {//1,创建键盘录入对象Scanner sc = new Scanner(System.in);System.out.println("请输入一个文件夹路径:");//2,定义一个无限循环while(true) {//3,将键盘录入的结果存储并封装成File对象String line = sc.nextLine();File dir = new File(line);//4,对File对象判断if(!dir.exists()) {System.out.println("您录入的文件夹路径不存在,请输入一个文件夹路径:");}else if(dir.isFile()) {System.out.println("您录入的是文件路径,请输入一个文件夹路径:");}else {//5,将文件夹路径对象返回return dir;}}}/** 统计该文件夹大小* 1,返回值类型long* 2,参数列表File dir*/public static long getFileLength(File dir) { //dir = F:\day06\day07//1,定义一个求和变量long len = 0;//2,获取该文件夹下所有的文件和文件夹listFiles();File[] subFiles = dir.listFiles(); //day07 Demo1_Student.class Demo1_Student.java//3,遍历数组for (File subFile : subFiles) {//4,判断是文件就计算大小并累加if(subFile.isFile()) {len = len + subFile.length();//5,判断是文件夹,递归调用}else {len = len + getFileLength(subFile);}}return len;}}
3、从键盘接收一个文件夹路径,删除该文件夹
package com.heima.test;import java.io.File;public class Test2 {/*** 需求:2,从键盘接收一个文件夹路径,删除该文件夹** 删除该文件夹* 分析:* 1,获取该文件夹下的所有的文件和文件夹* 2,遍历数组* 3,判断是文件直接删除* 4,如果是文件夹,递归调用* 5,循环结束后,把空文件夹删掉*/public static void main(String[] args) {File dir = Test1.getDir(); //获取文件夹路径deleteFile(dir);}/** 删除该文件夹* 1,返回值类型 void* 2,参数列表File dir*/public static void deleteFile(File dir) {//1,获取该文件夹下的所有的文件和文件夹File[] subFiles = dir.listFiles();//2,遍历数组for (File subFile : subFiles) {//3,判断是文件直接删除if(subFile.isFile()) {subFile.delete();//4,如果是文件夹,递归调用}else {deleteFile(subFile);}}//5,循环结束后,把空文件夹删掉dir.delete();}}
4、从键盘接收两个文件夹路径,把其中一个文件夹中(包含内容)拷贝到另一个文件夹中
package com.heima.test;import java.io.BufferedInputStream;import java.io.BufferedOutputStream;import java.io.File;import java.io.FileInputStream;import java.io.FileNotFoundException;import java.io.FileOutputStream;import java.io.IOException;public class Test3 {/*** 需求:3,从键盘接收两个文件夹路径,把其中一个文件夹中(包含内容)拷贝到另一个文件夹中** 把其中一个文件夹中(包含内容)拷贝到另一个文件夹中* 分析:* 1,在目标文件夹中创建原文件夹* 2,获取原文件夹中所有的文件和文件夹,存储在File数组中* 3,遍历数组* 4,如果是文件就用io流读写* 5,如果是文件夹就递归调用* @throws IOException*/public static void main(String[] args) throws IOException {File src = Test1.getDir();File dest = Test1.getDir();if(src.equals(dest)) {System.out.println("目标文件夹是源文件夹的子文件夹");}else {copy(src,dest);}}/** 把其中一个文件夹中(包含内容)拷贝到另一个文件夹中* 1,返回值类型void* 2,参数列表File src,File dest*/public static void copy(File src, File dest) throws IOException {//1,在目标文件夹中创建原文件夹File newDir = new File(dest, src.getName());newDir.mkdir();//2,获取原文件夹中所有的文件和文件夹,存储在File数组中File[] subFiles = src.listFiles();//3,遍历数组for (File subFile : subFiles) {//4,如果是文件就用io流读写if(subFile.isFile()) {BufferedInputStream bis = new BufferedInputStream(new FileInputStream(subFile));BufferedOutputStream bos =new BufferedOutputStream(new FileOutputStream(new File(newDir,subFile.getName())));int b;while((b = bis.read()) != -1) {bos.write(b);}bis.close();bos.close();//5,如果是文件夹就递归调用}else {copy(subFile,newDir);}}}}
5、从键盘接收一个文件夹路径,把文件夹中的所有文件以及文件夹的名字按层级打印
package com.heima.test;import java.io.File;public class Test4 {/*** 需求:4,从键盘接收一个文件夹路径,把文件夹中的所有文件以及文件夹的名字按层级打印, 例如:* 把文件夹中的所有文件以及文件夹的名字按层级打印* 分析:* 1,获取所有文件和文件夹,返回的File数组* 2,遍历数组* 3,无论是文件还是文件夹,都需要直接打印* 4,如果是文件夹,递归调用* day07* day08* xxx.jpg* yyy.txt* Demo1_Consturctor.class* Demo1_Consturctor.java* Demo1_Student.class* Demo1_Student.java*/public static void main(String[] args) {File dir = Test1.getDir(); //获取文件夹路径printLev(dir,0);}public static void printLev(File dir,int lev) {//1,把文件夹中的所有文件以及文件夹的名字按层级打印File[] subFiles = dir.listFiles();//2,遍历数组for (File subFile : subFiles) {for(int i = 0; i <= lev; i++) {System.out.print("\t");}//3,无论是文件还是文件夹,都需要直接打印System.out.println(subFile);//4,如果是文件夹,递归调用if(subFile.isDirectory()) {//printLev(subFile,lev + 1);printLev(subFile,++lev);}}}}
import java.io.File;/*** 打印层级目录* @author haoyongliang**/public class Demo5 {public static void main(String[] args) {show("E:\\JackDB-SQL-Database-Client_v3.0.0",0);}public static void show(String fileDir, int level){File file = new File(fileDir);//1、打印空格for(int i=0; i<level; i++){System.out.print("\t");}//2、打印文件或者文件夹名System.out.println(file.getAbsolutePath());//3、如果要是文件夹,继续递归if(file.isDirectory()){File[] listFiles = file.listFiles();if(listFiles != null){for(File f : listFiles){show(f.getAbsolutePath(),level+1);}}}}}
6、斐波那契-不死神兔
package com.heima.test;public class Test5 {/*** * 不死神兔* 故事得从西元1202年说起,话说有一位意大利青年,名叫斐波那契。* 在他的一部著作中提出了一个有趣的问题:假设一对刚出生的小兔一个月后就能长成大兔,再过一个月就能生下一对小兔,并且此后每个月都生一对小兔,一年内没有发生死亡,* 问:一对刚出生的兔子,一年内繁殖成多少对兔子?* 1 1 2 3 5 8 13 21* 1 = fun(1)* 1 = fun(2)* 2 = fun(1) + fun(2)* 3 = fun(2) + fun(3)*/public static void main(String[] args) {//demo1();System.out.println(fun(8));}public static void demo1() {//用数组做不死神兔int[] arr = new int[8];//数组中第一个元素和第二个元素都为1arr[0] = 1;arr[1] = 1;//遍历数组对其他元素赋值for(int i = 2; i < arr.length; i++) {arr[i] = arr[i - 2] + arr[i - 1];}//如何获取最后一个数System.out.println(arr[arr.length - 1]);}/** 用递归求斐波那契数列*/public static int fun(int num) {if(num == 1 || num == 2) {return 1;}else {return fun(num - 2) + fun(num - 1);}}}
7、求出1000的阶乘所有零和尾部零的个数,不用递归做
package com.heima.test;import java.math.BigInteger;public class Test6 {/*** @param args* 需求:求出1000的阶乘所有零和尾部零的个数,不用递归做*/public static void main(String[] args) {/*int result = 1;for(int i = 1; i <= 1000; i++) {result = result * i;}System.out.println(result); //因为1000的阶乘远远超出了int的取值范围*///demo1();demo2();}public static void demo2() { //获取1000的阶乘尾部有多少个零BigInteger bi1 = new BigInteger("1");for(int i = 1; i <= 1000; i++) {BigInteger bi2 = new BigInteger(i+"");bi1 = bi1.multiply(bi2); //将bi1与bi2相乘的结果赋值给bi1}String str = bi1.toString(); //获取字符串表现形式StringBuilder sb = new StringBuilder(str);str = sb.reverse().toString(); //链式编程int count = 0; //定义计数器for(int i = 0; i < str.length(); i++) {if('0' != str.charAt(i)) {break;}else {count++;}}System.out.println(count);}public static void demo1() { //求1000的阶乘中所有的零BigInteger bi1 = new BigInteger("1");for(int i = 1; i <= 1000; i++) {BigInteger bi2 = new BigInteger(i+"");bi1 = bi1.multiply(bi2); //将bi1与bi2相乘的结果赋值给bi1}String str = bi1.toString(); //获取字符串表现形式int count = 0;for(int i = 0; i < str.length(); i++) {if('0' == str.charAt(i)) { //如果字符串中出现了0字符count++; //计数器加1}}System.out.println(count);}}
8、约瑟夫环
package com.heima.test;import java.util.ArrayList;public class Test8 {/*** @param args* 约瑟夫环* * 幸运数字*/public static void main(String[] args) {System.out.println(getLucklyNum(8));}/** 获取幸运数字* 1,返回值类型int* 2,参数列表int num*/public static int getLucklyNum(int num) {ArrayList<Integer> list = new ArrayList<>(); //创建集合存储1到num的对象for(int i = 1; i <= num; i++) {list.add(i); //将1到num存储在集合中}int count = 1; //用来数数的,只要是3的倍数就杀人for(int i = 0; list.size() != 1; i++) { //只要集合中人数超过1,就要不断的杀if(i == list.size()) { //如果i增长到集合最大的索引+1时i = 0; //重新归零}if(count % 3 == 0) { //如果是3的倍数list.remove(i--); //就杀人}count++;}return list.get(0);}}
9、今天必须掌握的内容,面试题,笔试题。(掌握这个就可以放心学习后面的知识了)
Day23_IO第五天的更多相关文章
- 《Django By Example》第五章 中文 翻译 (个人学习,渣翻)
书籍出处:https://www.packtpub.com/web-development/django-example 原作者:Antonio Melé (译者@ucag注:大家好,我是新来的翻译, ...
- 旺财速啃H5框架之Bootstrap(五)
在上一篇<<旺财速啃H5框架之Bootstrap(四)>>做了基本的框架,<<旺财速啃H5框架之Bootstrap(二)>>篇里也大体认识了bootst ...
- 移动站应该尝试百度MIP的五个原因
MIP是什么?MIP是百度在2016年提出的移动网页加速器项目. MIP能做什么?MIP能帮助站长和网站开发者快速搭建移动端页面. MIP怎么加速?MIP从前端渲染和页面网络传输两方面进行优化,杜绝页 ...
- 如何一步一步用DDD设计一个电商网站(五)—— 停下脚步,重新出发
阅读目录 前言 单元测试 纠正错误,重新出发 结语 一.前言 实际编码已经写了2篇了,在这过程中非常感谢有听到观点不同的声音,借着这个契机,今天这篇就把大家提出的建议一个个的过一遍,重新整理,重新出发 ...
- MVVM模式解析和在WPF中的实现(五)View和ViewModel的通信
MVVM模式解析和在WPF中的实现(五) View和ViewModel的通信 系列目录: MVVM模式解析和在WPF中的实现(一)MVVM模式简介 MVVM模式解析和在WPF中的实现(二)数据绑定 M ...
- 【原】AFNetworking源码阅读(五)
[原]AFNetworking源码阅读(五) 本文转载请注明出处 —— polobymulberry-博客园 1. 前言 上一篇中提及到了Multipart Request的构建方法- [AFHTTP ...
- JavaScript常见的五种数组去重的方式
▓▓▓▓▓▓ 大致介绍 JavaScript的数组去重问题在许多面试中都会遇到,现在做个总结 先来建立一个数组 var arr = [1,2,3,3,2,'我','我',34,'我的',NaN,NaN ...
- 带你实现开发者头条APP(五)--RecyclerView下拉刷新上拉加载
title: 带你实现开发者头条APP(五)--RecyclerView下拉刷新上拉加载 tags: -RecyclerView,下拉刷新,上拉加载更多 grammar_cjkRuby: true - ...
- CRL快速开发框架系列教程五(使用缓存)
本系列目录 CRL快速开发框架系列教程一(Code First数据表不需再关心) CRL快速开发框架系列教程二(基于Lambda表达式查询) CRL快速开发框架系列教程三(更新数据) CRL快速开发框 ...
随机推荐
- background复合属性详解(上):background-image
background复合属性是个很复杂的属性,花样非常多,比较神奇的是css3 中支持多图片背景了,这篇文章先讲讲background-image属性,其他背景属性会在后续的文章综合总结. 一.最基本 ...
- 用cmd命令行导数据
Imp hbtest/hbtest@moms file=d:/hj.dmp fromuser=moms touser=hbtest 也可以用PL/SQL Developer "工具&quo ...
- [WebServer] Windows操作系统下 Tomcat 服务器运行 PHP 的环境配置
前言: 由于本人在开发和学习过程中需要同时部署 JavaWeb 和 PHP 项目,于是整理了网上的一些相关资料,并结合自己的实际操作,记录于此,以供参考. 一.环境(64bit): 1.操作系统.To ...
- JS-DOM基础
1 JS-DOM 全称:document object model 1.1 获取页面元素 getElementsByTagName():无论元素的数量是多少,都会存入数组 getElement ...
- ICEM(2)—机翼翼稍网格绘制
有时我们需要观察翼尖涡,这就需要将机翼全部被网格包围.但是网上比较多的教程都是机翼边缘即为网格边缘,机翼位于网格内部的不多.若是直接将网格拉伸,则会产生结构和非结构网格交错的情况.下面是绘制步骤 1. ...
- Java String.split()小点
java String.split(); 别的不说,单说其中一个问题,这个函数去切分空字符串时,得到的结果: public static void main(String[] args) {// St ...
- GridView获取列子段的几种途径
GridView是ASP.NET中功能强大的数据显示控件,它的RowDataBound事件为我们提供了方便的控制行.列数据的途径. 要获取当前行的某个数据列,我在实践中总结有如下几种方法: 1. Ce ...
- 前端开发week2
从网页布局看思维方式以及思维方式对于前端制作的重要性 经过了两个星期的学习,对于静态网页的制作也已经有了比较完整的理论知识和实践基础,技术层面的东西固然还是很重要.是最基础的,但是在实际制作网页的过程 ...
- 2013年最棒的4个PHP框架
PHP 框架可以帮你编写简洁可重用的代码,遵循 MVC 模式,确保应用逻辑和展现分离.有很多很多的框架各有千秋,有的性能好,有的文档全,还有的提供大量的内建功能等等. 这里我们罗列的 2013 年最好 ...
- could not build module 'XXXXXXXX'或者error: expected identifier or '(' 。一堆奇怪的错误————错误根源
一堆奇怪的错误:1⃣️could not build module 'XXXXXXXX' 2⃣️error: expected identifier or '(' 3⃣️EDIT Setting Pr ...