-
-
Notifications
You must be signed in to change notification settings - Fork 17
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
1 parent
4651285
commit 3dd586e
Showing
2 changed files
with
152 additions
and
0 deletions.
There are no files selected for viewing
76 changes: 76 additions & 0 deletions
76
Python/02 - Data_Structures/01 - Arrays/Easy/Maximum_in_Array.ipynb
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,76 @@ | ||
{ | ||
"cells": [ | ||
{ | ||
"cell_type": "markdown", | ||
"metadata": {}, | ||
"source": [ | ||
"# Find the Maximum and Minimum in an Array\n", | ||
"\n", | ||
"**Problem:** *Given an array, write a Python function to find the maximum and minimum elements.*\n", | ||
"\n", | ||
"**Example:**\n", | ||
"\n", | ||
"arr = [3, 5, 7, 2, 8]\n", | ||
"\n", | ||
"**Output:** Max = 8, Min = 2" | ||
] | ||
}, | ||
{ | ||
"cell_type": "code", | ||
"execution_count": 1, | ||
"metadata": {}, | ||
"outputs": [ | ||
{ | ||
"name": "stdout", | ||
"output_type": "stream", | ||
"text": [ | ||
"Max = 8,Min = 2\n" | ||
] | ||
} | ||
], | ||
"source": [ | ||
"def find_max_min(arr):\n", | ||
" if len(arr) == 0: # Check for an empty array\n", | ||
" return None, None\n", | ||
"\n", | ||
" max_val = arr[0] # Initialize max and min with the first element\n", | ||
" min_val = arr[0]\n", | ||
"\n", | ||
" for num in arr:\n", | ||
" if num > max_val:\n", | ||
" max_val = num\n", | ||
" if num < min_val:\n", | ||
" min_val = num\n", | ||
"\n", | ||
" return max_val, min_val\n", | ||
"\n", | ||
"# Example\n", | ||
"arr = [3, 5, 7, 2, 8]\n", | ||
"Max , Min = find_max_min(arr)\n", | ||
"\n", | ||
"print(f\"Max = {Max},Min = {Min}\")\n" | ||
] | ||
} | ||
], | ||
"metadata": { | ||
"kernelspec": { | ||
"display_name": "base", | ||
"language": "python", | ||
"name": "python3" | ||
}, | ||
"language_info": { | ||
"codemirror_mode": { | ||
"name": "ipython", | ||
"version": 3 | ||
}, | ||
"file_extension": ".py", | ||
"mimetype": "text/x-python", | ||
"name": "python", | ||
"nbconvert_exporter": "python", | ||
"pygments_lexer": "ipython3", | ||
"version": "3.12.5" | ||
} | ||
}, | ||
"nbformat": 4, | ||
"nbformat_minor": 2 | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,76 @@ | ||
# Mastering Data Structures and Algorithms in Python | ||
|
||
Python has rapidly become one of the most popular programming languages, with over 10 million developers utilizing its versatility and simplicity across a wide range of applications. In addition to its growing popularity, Python offers lucrative career opportunities, with an average base pay reaching $110,000 per year. Known for its readability, flexibility, and vast libraries, Python finds use across multiple domains, including web development, artificial intelligence, machine learning, scientific computing, and beyond. | ||
|
||
## Unlocking the Power of Data Structures and Algorithms (DSA) in Python | ||
|
||
Data Structures and Algorithms (DSA) are foundational to programming, enabling developers to solve complex problems efficiently. This article will guide you through mastering DSA using Python, one of the most beginner-friendly yet powerful programming languages in the world. | ||
|
||
### Introduction to Python DSA | ||
|
||
Python is widely regarded for its clean syntax and rapid prototyping capabilities, making it an excellent language for solving computational problems using Data Structures and Algorithms. Its rich ecosystem of libraries like NumPy, Pandas, and collections offer optimized implementations of fundamental data structures and algorithms, simplifying development tasks. | ||
|
||
### Understanding Data Structures and Algorithms | ||
|
||
**Data Structures**: Data structures are fundamental to organizing, storing, and retrieving data efficiently. Python supports various built-in data structures like lists, tuples, sets, and dictionaries, each suited for specific data management needs. | ||
|
||
**Algorithms**: Algorithms provide systematic steps to solve computational problems. In Python, you can implement a wide range of algorithms for tasks like searching, sorting, and optimizing, with simple and readable code. | ||
|
||
#### Data Structures Concepts: | ||
• **Lists in Python** | ||
• **Dictionaries** | ||
• **Collections** | ||
|
||
### Importance of Data Structures and Algorithms | ||
|
||
Data Structures and Algorithms are essential for efficient code, enhancing performance by reducing time complexity and optimizing resource utilization. Efficient DSA usage allows Python developers to solve real-world problems with solutions that scale, such as searching through large datasets using optimized algorithms like Binary Search, or handling data collisions in Hash Tables. | ||
|
||
### Core Data Structures in Python | ||
|
||
**Lists**: Lists in Python are mutable and can hold elements of different data types. They offer the flexibility to implement sorting and searching algorithms efficiently. | ||
|
||
**Dictionaries**: Similar to Hash Tables, dictionaries map keys to values, providing an efficient way to store and retrieve data with average O(1) time complexity. | ||
|
||
**Tuples and Sets**: While tuples are immutable sequences, sets are unordered collections of unique elements. Both data structures can be useful in specific scenarios, like ensuring data uniqueness or handling immutable objects. | ||
|
||
**Stacks and Queues**: Stacks operate on the Last In, First Out (LIFO) principle, while queues follow the First In, First Out (FIFO) rule. Python’s `collections.deque` is an efficient way to implement these data structures. | ||
|
||
**Trees and Graphs**: Although Python doesn’t have a built-in Tree or Graph data structure, libraries like `networkx` make it easy to implement them and solve complex problems in hierarchical or networked data. | ||
|
||
### Common Algorithms in Python | ||
|
||
**Sorting Algorithms**: Python’s built-in `sort()` method uses Timsort, an adaptive sorting algorithm with O(n log n) complexity. Other popular algorithms like Quick Sort, Merge Sort, and Bubble Sort can also be easily implemented in Python. | ||
|
||
**Searching Algorithms**: From Linear Search to Binary Search, Python allows you to perform efficient element searches within datasets using a few lines of code. | ||
|
||
**Graph Algorithms**: Python libraries such as `networkx` facilitate the implementation of BFS, DFS, and Shortest-Path algorithms like Dijkstra’s Algorithm to traverse and manipulate graph data efficiently. | ||
|
||
**Dynamic Programming**: Python’s flexibility makes it an ideal choice for implementing dynamic programming algorithms like the Knapsack Problem, Longest Common Subsequence, and Fibonacci sequence optimizations. | ||
|
||
### Applications of Python DSA | ||
|
||
The practical applications of Python DSA extend across numerous industries: | ||
|
||
- **Web Development**: Python’s data structures and algorithms play a critical role in backend development, enabling efficient data handling in web applications. | ||
|
||
- **Artificial Intelligence**: In AI and machine learning, Python is the go-to language. DSA is pivotal in optimizing models, handling large datasets, and enhancing performance. | ||
|
||
- **Finance**: Python DSA is used for algorithmic trading, risk management, and complex financial modeling, delivering efficient and scalable solutions. | ||
|
||
- **Data Science**: Python's powerful data structures and optimized algorithms are essential for data manipulation, statistical analysis, and machine learning tasks in data science. | ||
|
||
### Conclusion: Empowering Solutions with Python DSA | ||
|
||
In conclusion, mastering Data Structures and Algorithms in Python is crucial for any developer aiming to tackle real-world challenges effectively. Python’s simplicity, combined with its powerful libraries, provides a seamless way to implement and optimize DSA, making it the language of choice for industries ranging from finance to AI. Whether you are a beginner or an experienced developer, Python DSA equips you with the tools to solve problems efficiently and optimize your applications. | ||
|
||
<div align="center"> | ||
|
||
--- | ||
|
||
*Authored by <a target="_blank" href="https://github.com/dhayananthb">Dhayananth B</a>* | ||
|
||
<p align="center"> | ||
Copyright © 2023 - 2024 <b><a target="_blank" href="https://github.com/SERVER-X-101">SERVER-X-101</a></b> All rights reserved. <br/> | ||
</p> | ||
|
||
</div> |