Travelling-SalesMan Problem in Home Delivery Management System
Travelling-SalesMan Problem in Home Delivery Management System
Overview:
This project tries to solve the Travelling Salesman Problem, optimizing the route for a delivery boy to cover a list of provided addresses efficiently. The program calculates the shortest route using the Nearest Neighbour algorithm and displays information such as distance, cost, and estimated time.
Files:
-  ShortestPath.cs: - Main form class containing the logic for the Travelling Salesman Problem application.
- Handles user input for delivery addresses and integrates with the Nearest Neighbour algorithm.
- Displays route details, including distance, cost, and estimated time.
- Manages the delivery boy queue and updates the route dynamically.
 
-  InsertBoy.cs: - Form class for inserting new delivery boys into the system.
- Allows users to add details of a new delivery boy, such as ID, name, and email.
 
-  Email.cs: - Class responsible for sending email notifications.
- Utilizes the SendEmailmethod to send route details to the selected delivery boy.
 
-  Settings.cs: - Form class providing settings options for the application.
- Users can configure parameters such as delivery speed and cost per kilometer.
 
Functionality:
-  Insert Addresses: - Users can input house and area details to add addresses for delivery.
- The application displays the entered addresses for reference.
 
-  Find Route: - When the user clicks the “Find Route” button, the application calculates the shortest route using the Nearest Neighbour algorithm.
- Information about the route, including distance, cost, and estimated time, is displayed.
 
-  Insert Delivery Boy: - Users can add new delivery boys by clicking the “Insert Delivery Boy” button.
- The InsertBoyform allows users to provide details such as ID, name, and email for the new delivery boy.
 
-  Send Email: - Clicking the “Send Email” button sends an email with the route details to the selected delivery boy.
 
-  Settings: - Users can access application settings by clicking the “Settings” button.
- The Settingsform allows users to configure parameters such as delivery speed and cost per kilometer.
 
-  Start/Stop Timer: - Users can start and stop the timer to measure the interval between route calculations.
 
Usage:
-  Insert Addresses: - Enter house and area details and click the “Add Address” button.
 
-  Find Route: - Click the “Find Route” button to calculate the shortest route.
 
-  Insert Delivery Boy: - Click the “Insert Delivery Boy” button to add a new delivery boy.
 
-  Send Email: - Click the “Send Email” button to send route details to the selected delivery boy.
 
-  Settings: - Click the “Settings” button to configure application parameters.
 
-  Start/Stop Timer: - Use the “Start Timer” and “Stop Timer” buttons to control the timer interval.
 
Notes:
- The application uses a dynamic queue (DynamicQueue) to manage delivery boys.
- The Nearest Neighbour algorithm is employed to find the shortest route.
- The program allows users to adjust settings such as delivery speed and cost per kilometer.
Dependencies:
- The application relies on external classes such as City,Route,NearestNeighbour,DeliveryBoy, andEmailfor various functionalities.
Additional Information:
- The application includes features such as sending email notifications, dynamic route calculation, and user-configurable settings.