數(shù)列和是數(shù)學(xué)中的一個(gè)常見問題,它通常可以用計(jì)算機(jī)程序來解決。Java語言提供了許多方法來求數(shù)列和,下面我們來一一介紹。
public static int sumForLoop(int[] arr) { int sum = 0; for(int i=0; i這個(gè)方法使用了for循環(huán)來迭代數(shù)組,并將每個(gè)元素加到sum變量中。這是最常見的方法,時(shí)間復(fù)雜度為O(n)。
public static int sumRecursive(int[] arr, int start, int end) { if(start == end) { return arr[start]; } else { int mid = (start+end)/2; int left = sumRecursive(arr, start, mid); int right = sumRecursive(arr, mid+1, end); return left + right; } }這個(gè)方法使用了遞歸技巧來計(jì)算數(shù)組的和。它將數(shù)組拆成兩半,遞歸地計(jì)算左半邊和右半邊的和,最后將它們相加。時(shí)間復(fù)雜度為O(nlogn)。
public static int sumStream(int[] arr) { return Arrays.stream(arr).sum(); }這個(gè)方法使用Java 8提供的Stream API來計(jì)算數(shù)組的和。它將數(shù)組轉(zhuǎn)換成一個(gè)IntStream對(duì)象,并使用sum()方法計(jì)算其和。這是最簡(jiǎn)單的方法,時(shí)間復(fù)雜度為O(n)。