半全场

半全场

滚球app(中国) 2026-06-06: 统计主导元素下标数。用go言语, 给定一个整数数组 nu

发布日期:2026-06-07 11:49 来源:未知 作者:admin 浏览次数:

滚球app(中国) 2026-06-06: 统计主导元素下标数。用go言语, 给定一个整数数组 nu

2026-06-06:统计主导元素下标数。用go言语,给定一个整数数组 nums,长度为 n。咱们称某个位置 i(经常只筹商 i

你的计算是统计数组中称心上述要求的位置数目,并输出该数目(最右端下标 n-1 对应的元素不参与判断)。

1

1

输入: nums = [5,4,3]。

输出: 2。

发挥:

不才标 i = 0 处,值 5 是主导元素,因为 5 > average(4, 3) = 3.5。

不才标 i = 1 处,值 4 是主导元素,相干于子数组 [3]。

下标 i = 2 不是主导元素,因为它右侧莫得元素。因此谜底是 2。

题目来独力扣3833。

1. 代码逻辑冉冉引申

启动:

• n = 3

• ans = 0

• sufSum = 0(用来累加后缀和,即 i+1 到末尾的和)

轮回 i = n-2 = 1向下到 0:

第一轮 i = 1:

• 先作念 sufSum += nums[i+1]

sufSum = 0 + nums[2] = 0 + 3 = 3

• 后缀长度 len = n-1-i = 3-1-1 = 1

• 检查 nums[1] * len > sufSum?

第二轮 i = 0:

• 先作念 sufSum += nums[i+1]

sufSum = 3 + nums[1] = 3 + 4 = 7

• 后缀长度 len = n-1-i = 3-1-0 = 2

• 检查 nums[0] * len > sufSum?

轮回扫尾,滚球app软件复返 ans = 2。

2. 算法中枢重心

• 从右往左遍历,用一个变量 sufSum 累加现时 i 右边的悉数元素和。

• 每次轮回源泉先加上 nums[i+1](对 i 来说即是它右侧紧邻的元素,但 sufSum 骨子是 i 右边全的和)。

• 这么只需要 O(1) 的独特变量,无谓每次从头策画后缀和。

• 比拟时用乘法幸免浮点数运算。

3. 本事复杂度

• 轮回 n-1 次(从 n-2 到 0),每次轮回 O(1) 操作。

• 总本事复杂度 O(n)。

4. 空间复杂度

• 除了输入数组,只用了 n, ans, sufSum 几个变量。

• 总和外空间复杂度 O(1)。

Go齐备代码如下:

package main

import (

"fmt"

)

func dominantIndices(nums []int) (ans int) {

n := len(nums)

sufSum := 0

for i := n - 2; i >= 0; i-- {

sufSum += nums[i+1]

if nums[i]*(n-1-i) > sufSum {

ans++

}

}

return

}

func main {

nums := []int{5, 4, 3}

result := dominantIndices(nums)

fmt.Println(result)

}

Python齐备代码如下:

# -*-coding:utf-8-*-

def dominant_indices(nums):

n = len(nums)

ans = 0

suf_sum = 0

for i in range(n - 2, -1, -1):

suf_sum += nums[i + 1]

if nums[i] * (n - 1 - i) > suf_sum:

ans += 1

return ans

if __name__ == "__main__":

nums = [5, 4, 3]

result = dominant_indices(nums)

print(result)

C++齐备代码如下:

#include

#include

using namespace std;

int dominantIndices(vector& nums) {

int n = nums.size;

int ans = 0;

int sufSum = 0;

for (int i = n - 2; i >= 0; i--) {

sufSum += nums[i + 1];

if (nums[i] * (n - 1 - i) > sufSum) {

ans++;

}

}

return ans;

}

int main {

凤凰彩票官网首页 - Welcome

vector nums = {5, 4, 3};

int result = dominantIndices(nums);

cout

return0;

}

咱们敬佩东说念主工智能为世俗东说念主提供了一种“增强用具”,并戮力于共享全方向的AI学问。在这里,您不错找到最新的AI科普著述、用具评测、擢升后果的秘密以及行业细察。

接待崇拜“福大大架构师逐日一题”滚球app(中国),发音讯可获取口试良友,让AI助力您的将来发展。

上一篇:上一篇:滚球app中国官方网站 哈登将迎来糊口第9次抢七决战 此前4胜4负!
下一篇:下一篇:没有了