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快速开发框 ...
随机推荐
- 50款强力jquey,js 插件推荐
http://www.cnblogs.com/xiaoyao2011/category/327551.html
- 线性控制原理——PID算法应用
使用控制系统(PID)控制被控对象 PID控制的三要素:控制器,被控对象,反馈器.控制器就是一个数学模型,就PID来说,等同于PID算法.是对反馈量的一个处理与输出.通俗的说就是对于每个被控的量,我的 ...
- SSH项目(1)
1.新建项目,添加jar包 tomcat jsp struts.hibernate.spring 2.配置 web.xml <?xml version="1.0" encod ...
- 白皮 Chapter 1
6.29 今天主要做了一些1.5中的小结和练习,果然换语言思路也要跟着变么…各种不爽啊不爽… scanf各种忘记&,还有各种忘记return 0… average temperature su ...
- 获取数据库表详细信息、存储过程、视图、的sql
select s.[name] + '.' + t.[name] as tablename from sys.tables as t,sys.schemas as s where t.schema_i ...
- Microsoft Azure Project Oxford 体验
2015年4月29日,微软在Build 2015大会上发布了一个震撼人心的项目: Project Oxford, 可以帮助直接实现图像理解.人脸识别.语音识别.语音合成等功能.虽然说这是号称研究院的项 ...
- OC基础--继承
继承的基本概念: 现实生活中的继承: 人类是一个基类(也称做父类),通常情况下所有人类所共同具备的特性,如有手有脚能吃能喝 按照生活常规,我们继续给人类来细分的时候,我们可以分为学生类 工人类等,学生 ...
- java多线程系列之 synchronized
一.synchronized基本原理 java的内置锁:每个java对象都可以用做一个实现同步的锁,这些锁成为内置锁.线程进入同步代码块或方法的时候会自动获得该锁,在退出同步代码块或方法时会释放该锁. ...
- readelf与动态库
使用arm-linux-gcc编译的可执行文件可能会无法在开发板上执行,并提示:-/bin/sh xxx not found 解决办法: 在主机上使用readelf -d xxx 来查看该程序所需要的 ...
- 玩转mysql-5.7.9-winx64.zip解压版
解压zip文件,放到D盘 追加\bin到Path环境变量 修改my-default.ini,# basedir =D:\mysql_5.7.9_winx64# datadir =D:\mysql_5. ...