PHP Program for Largest Sum Contiguous Subarray
What is PHP?
PHP (Hypertext Preprocessor) is a widely used server-side scripting language for web development. It allows developers to embed code within HTML files, enabling the creation of dynamic web pages and interactions with databases. PHP is known for its simplicity, versatility, and extensive integration capabilities with popular databases. It offers a broad range of extensions and has a large community of developers, ensuring ample resources and support.
PHP Program for Largest Sum Contiguous Subarray
4+ (-1) +2 +1 = 6
Maximum contiguous sum is = 6
Using Kadane's Algorithm
Kadane's Algorithm is an efficient algorithm used to find the maximum sum of a contiguous subarray within a given array. It was developed by Jay Kadane in 1984.
The algorithm works by iteratively scanning the array and maintaining two variables: max_so_far and max_ending_here. Here's how the algorithm works:
Initialize max_so_far and max_ending_here variables to the first element of the array or to a minimum value (e.g., PHP_INT_MIN) if the array contains negative numbers.
Iterate through the array from the second element onwards.
For each element, update max_ending_here by adding the current element to it.
If max_ending_here becomes negative, reset it to 0 because including the current element in the subarray will decrease the sum.
If max_ending_here is greater than max_so_far, update max_so_far with the new maximum sum.
Repeat steps 3 to 5 for the remaining elements of the array.
After iterating through the entire array, max_so_far will hold the maximum sum of a contiguous subarray.
Return max_so_far as the result.
Kadane's Algorithm has a time complexity of O(n), where n is the size of the array, as it only requires a single pass through the array. This makes it an efficient solution for finding the maximum sum contiguous subarray.
Example
<?php // PHP program to print largest // contiguous array sum function maxSubArraySum($a, $size) { $max_so_far = PHP_INT_MIN; $max_ending_here = 0; for ($i = 0; $i < $size; $i++) { $max_ending_here = $max_ending_here + $a[$i]; if ($max_so_far < $max_ending_here) $max_so_far = $max_ending_here; if ($max_ending_here < 0) $max_ending_here = 0; } return $max_so_far; } // Driver code $a = array(-2, 1, -3, 4, -1, 2, 1, -5, 4); $n = count($a); $max_sum = maxSubArraySum($a, $n); echo "Maximum contiguous sum is " , $max_sum; ?>
Output
Maximum contiguous sum is 6
Using Algorithmic Paradigm: Dynamic Programming
Example
<?php function maxSubArraySum($a, $size) { $max_so_far = $a[0]; $curr_max = $a[0]; for ($i = 1; $i < $size; $i++) { $curr_max = max($a[$i], $curr_max + $a[$i]); $max_so_far = max($max_so_far, $curr_max); } return $max_so_far; } // Driver Code $a = array(-2, 1, -3, 4, -1, 2, 1, -5, 4); $n = sizeof($a); $max_sum = maxSubArraySum($a, $n); echo "Maximum contiguous sum is " . $max_sum; ?>
Output
Maximum contiguous sum is 6
Another approach with start and end indexes
Example
<?php // PHP program to print largest // contiguous array sum function maxSubArraySum($a, $size) { $max_so_far = PHP_INT_MIN; $max_ending_here = 0; $start = 0; $end = 0; $s = 0; for ($i = 0; $i < $size; $i++) { $max_ending_here += $a[$i]; if ($max_so_far < $max_ending_here) { $max_so_far = $max_ending_here; $start = $s; $end = $i; } if ($max_ending_here < 0) { $max_ending_here = 0; $s = $i + 1; } } echo "Maximum contiguous sum is ". $max_so_far."<br>"; echo "Starting index ". $start . "<br>". "Ending index " . $end . "<br>"; } // Driver Code $a = array(-2, 1, -3, 4, -1, 2, 1, -5, 4); $n = sizeof($a); $max_sum = maxSubArraySum($a, $n); ?>
Output
Maximum contiguous sum is 6 Starting index 3 Ending index 6
Conclusion
The PHP program for finding the largest sum contiguous subarray utilizes dynamic programming and Kadane's algorithm. The dynamic programming approach is employed to efficiently solve the problem by breaking it down into smaller sub problems and storing the solutions in an array.
Kadane's algorithm is a key component of the program and is responsible for finding the largest sum contiguous subarray. It iterates over the array, continuously updating the current sum by either adding the current element or starting a new subarray. The maximum sum encountered is stored in the $maxSum variable. The program efficiently handles both positive and negative numbers in the array. It identifies the subarray with the largest sum by keeping track of the start and end indices, allowing for the extraction of the subarray using array_slice.
By utilizing dynamic programming and Kadane's algorithm, the program achieves a time complexity of O(n), where n is the size of the array. This ensures an efficient solution for finding the largest sum contiguous subarray in PHP.
The above is the detailed content of PHP Program for Largest Sum Contiguous Subarray. For more information, please follow other related articles on the PHP Chinese website!

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics



PHP 8.4 brings several new features, security improvements, and performance improvements with healthy amounts of feature deprecations and removals. This guide explains how to install PHP 8.4 or upgrade to PHP 8.4 on Ubuntu, Debian, or their derivati

Visual Studio Code, also known as VS Code, is a free source code editor — or integrated development environment (IDE) — available for all major operating systems. With a large collection of extensions for many programming languages, VS Code can be c

If you are an experienced PHP developer, you might have the feeling that you’ve been there and done that already.You have developed a significant number of applications, debugged millions of lines of code, and tweaked a bunch of scripts to achieve op

This tutorial demonstrates how to efficiently process XML documents using PHP. XML (eXtensible Markup Language) is a versatile text-based markup language designed for both human readability and machine parsing. It's commonly used for data storage an

JWT is an open standard based on JSON, used to securely transmit information between parties, mainly for identity authentication and information exchange. 1. JWT consists of three parts: Header, Payload and Signature. 2. The working principle of JWT includes three steps: generating JWT, verifying JWT and parsing Payload. 3. When using JWT for authentication in PHP, JWT can be generated and verified, and user role and permission information can be included in advanced usage. 4. Common errors include signature verification failure, token expiration, and payload oversized. Debugging skills include using debugging tools and logging. 5. Performance optimization and best practices include using appropriate signature algorithms, setting validity periods reasonably,

A string is a sequence of characters, including letters, numbers, and symbols. This tutorial will learn how to calculate the number of vowels in a given string in PHP using different methods. The vowels in English are a, e, i, o, u, and they can be uppercase or lowercase. What is a vowel? Vowels are alphabetic characters that represent a specific pronunciation. There are five vowels in English, including uppercase and lowercase: a, e, i, o, u Example 1 Input: String = "Tutorialspoint" Output: 6 explain The vowels in the string "Tutorialspoint" are u, o, i, a, o, i. There are 6 yuan in total

Static binding (static::) implements late static binding (LSB) in PHP, allowing calling classes to be referenced in static contexts rather than defining classes. 1) The parsing process is performed at runtime, 2) Look up the call class in the inheritance relationship, 3) It may bring performance overhead.

What are the magic methods of PHP? PHP's magic methods include: 1.\_\_construct, used to initialize objects; 2.\_\_destruct, used to clean up resources; 3.\_\_call, handle non-existent method calls; 4.\_\_get, implement dynamic attribute access; 5.\_\_set, implement dynamic attribute settings. These methods are automatically called in certain situations, improving code flexibility and efficiency.
