A directory/folder is a File System used in computing that acts as a named memory location for storing related files or even subfolders. This allows better management of files and folders and is premised on the concept of real-world folders used for storing files. This system is the implementation of compartmentalization of the memory and makes the working space more organized. The Directory File System allows hierarchical arrangement as well as nesting of directories inside other directories.
Recursion is the process through which a function calls itself. It is a very useful approach to break down complex problems into smaller subparts.
Approaches:
- Using the mkdir() method
- Using the createDirectory() method of the java.nio package
1. Using the mkdir() Method
The first approach is to import the java.io.File class and define a method named file() which internally makes use of the mkdir() function to recursively create directories. The algorithm used inside the file() method is described below.
Algorithm:
- Create the file() method with the return type as void.
- This method takes three parameters :
- String md which stands for Main Directory.
- String path which stands for the directory structure to be made where each character means a new directory
- Int depth represents the number of directories to be made.
- Declare the terminating condition as if (depth == 0) return.
- Decrement the depth for each recursive call.
- Check if the path string is 0 in length and display the message accordingly.
- Append the md with the first character of the path string and remove the first character from the path string for each recursive call.
- Create an object of the File class with md as a parameter.
- Check if the directory already exists using the exists() method and display the message.
- Else create the directory using the mkdir()method.
- Make the recursive call.
Implementation: Below is the implementation of the above program.
Java
// Java Program to Create Directories Recursively // Importing required classes import java.io.File; // Main class class GFG { // Method // To create directories static void file(String md, String path, int depth) { // md stores the starting path each character in // path represents new directory depth stores // the number of directories to be created // terminating condition if (depth == 0 ) return ; // Decrementing the depth by 1 depth -= 1 ; // Checking if the path exists if (path.length() == 0 ) System.out.println( "Path does not exist" ); // execute if the path has more directories else { // appending the next directory // would be md = md + "\\" + // path.charAt(0) for windows md = md + "/" + path.charAt( 0 ); // removing the first character // from path string path = path.substring( 1 ); // creating File object File f = new File(md); // if the directory already exists if (f.exists()) { System.out.println( "The Directory " + "already exists" ); } else { // creating the directory boolean val = f.mkdir(); if (val) System.out.println(md + " created" + " successfully" ); else System.out.println( "Unable to " + "create Directory" ); } } // recursive call file(md, path, depth); } // Driver method public static void main(String[] args) { // creating class object GFG ob = new GFG(); // path for windows -> "C:\\Users\\ // harshit\\Desktop" ob.file( "/home/mayur/Desktop" , "abcd" , 4 ); } } |
Output:
Time complexity: O(n),The time complexity of the above program is O(n) as the program is iterating through the string characters one by one to create the directories.
Space complexity: O(1),The space complexity of the above program is O(1) as no extra space is required for execution.
2. Using the createDirectory() method of the java.nio package
This approach makes use of java.nio package to implement the code. We deploy the createDirectories() method here to create new directories. We also make use of the try-catch block to catch IO Errors. The Algorithm can be found below.
Algorithm:
- Repeat steps through 1-6 as mentioned in the algorithm in approach 1.
- Now, convert the string md to Path Instance using Path.gets() method.
- Again, check if the Directory already exists using the exists() method.
- If the Directory is not present, open a try-catch block, and create a new directory using createDirectories() method.
- Else, display that the Directory already exists.
- Make the recursive call
Below is the implementation of the above program.
Java
// Java code to create directories recursively // importing the packages import java.nio.file.Paths; import java.nio.file.Path; import java.nio.file.Files; import java.io.IOException; class GFG { // defining the recursive method static void file(String md, String path, int depth) { // base case if (depth == 0 ) return ; // decrement the depth depth -= 1 ; // check if the path is empty if (path.length() == 0 ) System.out.println( "Path does not exist" ); else { // appending the first character from // path string md = md + "/" + path.charAt( 0 ); // removing the first character from // path string path = path.substring( 1 ); // creating the path instance from // path string Path p = Paths.get(md); // if the directory already exists if (!Files.exists(p)) { try { // creating directory Files.createDirectories(p); System.out.println(md + " created" + " successfully" ); } catch (IOException err) { err.printStackTrace(); } } else System.out.println( "The directory " + "already exists" ); } // recursive call file(md, path, depth); } // Driver Code public static void main(String[] args) { // creating the object of the class GFG ob = new GFG(); // md would be -> "C:\\Users\\harshit\\ // Desktop for windows ob.file( "/home/mayur/Desktop" , "klm" , 5 ); } } |
Output:
Time Complexity: O(N), where N is the number of characters in the path string.
Space Complexity: O(N) to store the path string in the recursive stack.