What is the primary characteristic of the binary search algorithm?

  • Divide and conquer algorithm
  • Dynamic programming algorithm
  • Greedy algorithm
  • Randomized algorithm
The primary characteristic of the binary search algorithm is that it follows a divide and conquer approach. It repeatedly divides the sorted array into halves and efficiently narrows down the search space.

Imagine you have a list of names sorted alphabetically, and you need to find a particular name. Would linear search or binary search be more suitable for this scenario? Justify your choice.

  • Binary search
  • Exponential search
  • Interpolation search
  • Linear search
In a scenario with a sorted list of names, binary search would be more suitable than linear search. Binary search has a time complexity of O(log n), making it more efficient for sorted data compared to the linear search with O(n) time complexity. Binary search consistently halves the search space, allowing for quicker identification of the target name.

Dynamic resizing of a hash table involves increasing or decreasing the size of the underlying array based on the _______ of the table.

  • Capacity
  • Load factor
  • Number of elements
  • Size of keys
Dynamic resizing of a hash table involves adjusting the size of the underlying array based on the load factor of the table. The load factor is the ratio of the number of elements to the size of the array, and resizing helps maintain a balance to ensure efficient performance.

What is the primary purpose of shortest path algorithms like Dijkstra's, Bellman-Ford, and Floyd-Warshall?

  • Discovering the path with the maximum number of edges.
  • Finding the longest path in a graph.
  • Identifying the path with the minimum sum of edge weights between two vertices.
  • Sorting vertices based on their degrees.
The primary purpose of shortest path algorithms such as Dijkstra's, Bellman-Ford, and Floyd-Warshall is to identify the path with the minimum sum of edge weights between two vertices. These algorithms are crucial for solving optimization problems related to network routing and transportation.

A queue follows the _______ principle where the first element added is the first one to be _______.

  • First-In-First-Out (FIFO), Removed
  • Last-In-First-Out (LIFO), Removed
  • Priority-Based-Out (PBO), Added
  • Random-In-First-Out (RIFO), Added
A queue follows the First-In-First-Out (FIFO) principle, where the first element added is the first one to be removed. This ensures that elements are processed in the order they are added, resembling a real-world queue or line.

What is the difference between a singly linked list and a doubly linked list?

  • A doubly linked list is more memory-efficient than a singly linked list.
  • A singly linked list allows traversal in both directions, while a doubly linked list allows traversal only in one direction.
  • A singly linked list has nodes with pointers only to the next node, while a doubly linked list has nodes with pointers to both the next and the previous nodes.
  • A singly linked list is limited to storing integers, while a doubly linked list can store any data type.
The main difference is that a singly linked list has nodes with pointers only to the next node, while a doubly linked list has nodes with pointers to both the next and the previous nodes. This allows for more flexible traversal in a doubly linked list.

Can selection sort be used efficiently for sorting nearly sorted arrays? Why or why not?

  • It depends on the size of the array and available memory
  • No, it performs poorly on nearly sorted arrays
  • Yes, but only if the array is sorted in descending order
  • Yes, it is specifically designed for nearly sorted arrays
No, selection sort performs poorly on nearly sorted arrays because it always makes the same number of comparisons and swaps, regardless of the input order, making it less efficient for partially ordered lists.

Discuss the time complexity of the dynamic programming approach for solving the coin change problem.

  • O(2^n)
  • O(n log n)
  • O(n)
  • O(n^2)
The time complexity of the dynamic programming approach for the coin change problem is O(2^n), where 'n' is the total amount to be made with coins. This is due to the recursive nature of the algorithm, which explores all possible combinations, resulting in exponential time complexity.

Dynamic programming optimizes the Matrix Chain Multiplication algorithm by _______.

  • Ignoring the order of multiplication.
  • Maximizing the number of matrices in the chain for better parallelization.
  • Minimizing the number of scalar multiplications required to compute the product of matrices.
  • Randomly rearranging the matrices before multiplication.
Dynamic programming optimizes the Matrix Chain Multiplication algorithm by minimizing the number of scalar multiplications required to compute the product of matrices. This is achieved through optimal parenthesization and storing intermediate results to avoid redundant calculations.

What is the significance of the LIS problem in real-world applications?

  • It is employed in DNA sequence analysis and stock market prediction.
  • It is mainly applied in image processing tasks.
  • It is primarily used in academic research and has limited practical applications.
  • It is used in data compression algorithms.
The Longest Increasing Subsequence (LIS) problem has real-world significance in applications such as DNA sequence analysis and stock market prediction. It helps identify patterns and trends in sequential data, making it valuable in various fields.