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快速开发框 ...
随机推荐
- android 照片地理位置 demo
类似qq空间的的带位置的水印相机实现: 基于高德地图的API实现获取地理位置信息.注意修改Androidmanifest.xml文件中的key.去高德地图api去申请自己的key. 现在网上搜索到的通 ...
- RP4412开发板在Android系统编译生成ramdisk-uboot.img
荣品RP4412开发板在android系统编译的时候,怎么生成ramdisk-uboot.img生成流程分析: mkimage -A arm -O linux -T ramdisk -C none - ...
- Ubuntu下Nutch1.2的使用
aaarticlea/png;base64,iVBORw0KGgoAAAANSUhEUgAAAeMAAABpCAIAAACGSdxlAAAAA3NCSVQICAjb4U/gAAAgAElEQVR4Xu ...
- SpringMVC 表单标签 & 处理静态资源
使用 Spring 的表单标签 通过 SpringMVC 的表单标签可以实现将模型数据中的属性和 HTML 表单元素相绑定,以实现表单数据更便捷编辑和表单值的回显. form 标签 一般情况下,通过 ...
- C++小项目:directx11图形程序(九):总结
整篇文章中对于directx11的知识的介绍并不多,我也不知道怎么介绍,也应该说对于directx,它有它自己的部分,比如设备(device),设备上下文(devicecontext),顶点缓存,索引 ...
- wx jssdk
public static Dictionary<string,string> jsstr(string url) { //noncestr ); //timestamp TimeSpan ...
- HttpRequestUtil
package com.didichuxing.tempdirreader; import com.alibaba.fastjson.JSONObject; import java.io.Unsupp ...
- 杭电ACM1002
原题:http://acm.hdu.edu.cn/showproblem.php?pid=1002 #include <stdio.h> #include <string.h> ...
- 又出头了,又SB了
前些天买冰箱的事啊.. 前些天卡激活的事啊.. 今天门禁的事情啊.. 自己真是大傻逼啊.. 自己表情非常难看.注意保持乐观帅气的笑容.
- Struts2中动态方法的调用
Struts2中动态方法调用就是为了解决一个action对应多个请求的处理,以免action太多. 主要有一下三种方法:指定method属性.感叹号方式和通配符方式.推荐使用第三种方式. 1.指定me ...