data:image/s3,"s3://crabby-images/ad064/ad0641647b7d11522f038c53d5235bc27d520884" alt="Learn Data Structures and Algorithms with Golang"
上QQ阅读APP看书,第一时间看更新
Linear complexity
An algorithm is of linear complexity if the processing time or storage space is directly proportional to the number of input elements to be processed. In Big O notation, linear complexity is presented as O(n). String matching algorithms such as the Boyer-Moore and Ukkonen have linear complexity.
Linear complexity, O(n), is demonstrated in an algorithm as follows:
//main package has examples shown
// in Go Data Structures and algorithms book
package main
// importing fmt package
import (
"fmt"
)
// main method
func main() {
var m [10]int
var k int
for k = 0; k < 10; k++ {
m[k] = k * 200
fmt.Printf("Element[%d] = %d\n", k, m[k] )
}
}
Run the following commands:
go run linear_complexity.go
The following screenshot displays the output:
data:image/s3,"s3://crabby-images/e90f7/e90f7310cb31ebf42f13bd240afa0c12d1b9acd6" alt=""
Let's take a look at quadratic complexity in the next section.