最大子数组

  1. /// ## maximum subarray via Dynamic Programming
  2. /// maximum_subarray(array) find the subarray (containing at least one number) which has the largest sum
  3. /// and return its sum.
  4. ///
  5. /// A subarray is a contiguous part of an array.
  6. ///
  7. /// Arguments:
  8. /// * `array` - an integer array
  9. /// Complexity
  10. /// - time complexity: O(array.length),
  11. /// - space complexity: O(array.length),
  12. pub fn maximum_subarray(array: &[i32]) -> i32 {
  13. let mut dp = vec![0; array.len()];
  14. dp[0] = array[0];
  15. let mut result = dp[0];
  16. for i in 1..array.len() {
  17. if dp[i - 1] > 0 {
  18. dp[i] = dp[i - 1] + array[i];
  19. } else {
  20. dp[i] = array[i];
  21. }
  22. result = result.max(dp[i]);
  23. }
  24. result
  25. }
  26. #[cfg(test)]
  27. mod tests {
  28. use super::*;
  29. #[test]
  30. fn non_negative() {
  31. //the maximum value: 1 + 0 + 5 + 8 = 14
  32. let array = vec![1, 0, 5, 8];
  33. assert_eq!(maximum_subarray(&array), 14);
  34. }
  35. #[test]
  36. fn negative() {
  37. //the maximum value: -1
  38. let array = vec![-3, -1, -8, -2];
  39. assert_eq!(maximum_subarray(&array), -1);
  40. }
  41. #[test]
  42. fn normal() {
  43. //the maximum value: 3 + (-2) + 5 = 6
  44. let array = vec![-4, 3, -2, 5, -8];
  45. assert_eq!(maximum_subarray(&array), 6);
  46. }
  47. #[test]
  48. fn single_element() {
  49. let array = vec![6];
  50. assert_eq!(maximum_subarray(&array), 6);
  51. let array = vec![-6];
  52. assert_eq!(maximum_subarray(&array), -6);
  53. }
  54. }