华为机考练习(golang)

输入 第一行输入一个正整数N,表示整数个数。(0<N<100000) 第二行输入N个整数,整数的取值范围为[-100,100]。 第三行输入一个正整数M,M代表窗口的大小,M<=100000,且M<=N。 输出 窗口滑动产生所有窗口和的最大值

Go 复制代码
package main

import (
	"bufio"
	"fmt"
	"os"
	"strconv"
	"strings"
)

func sumOfIntSlice(list []int) int {
	sum := 0
	for _, i := range list {
		sum += i
	}

	return sum
}

func maxIntOfSlice(list []int) int {
	max := 0
	for _, i := range list {
		if i > max {
			max = i
		}
	}

	return max
}

func main() {
	n := 0                 //整数个数
	list := make([]int, 0) //输入的整数列表
	m := 0                 //窗口宽度

	reader := bufio.NewReader(os.Stdin)

	fmt.Println("请输入整数个数N:")
	if nStr, err := reader.ReadString('\n'); err != nil {
		fmt.Println("获取参数N有错误", err)
		return
	} else {
		if nInt, err1 := strconv.Atoi(strings.TrimSpace(nStr)); err1 != nil {
			fmt.Sprintln("输入的参数N不是整数")
			return
		} else {
			n = nInt
		}
	}

	fmt.Println("请输入N个数字,并以空格隔开")
	if listInputStr, err := reader.ReadString('\n'); err != nil {
		fmt.Println("获取输入N个数字错误", err)
		return
	} else {
		listStr := strings.Split(strings.TrimSpace(listInputStr), " ")
		if len(listStr) == 0 {
			fmt.Println("数据参数不能为空")
			return
		} else {
			for _, intStrItem := range listStr {
				if intItem, err1 := strconv.Atoi(strings.TrimSpace(intStrItem)); err1 != nil {
					fmt.Println(fmt.Sprintf("%s 输入的参数:'%s'中包含非数字内容", listInputStr, intStrItem), err1)
					return
				} else {
					list = append(list, intItem)
				}
			}
		}
	}

	fmt.Println("请输入参数M")
	if mStr, err := reader.ReadString('\n'); err != nil {
		fmt.Println("获取参数M失败", err)
		return
	} else {
		if mInt, err1 := strconv.Atoi(strings.TrimSpace(mStr)); err1 != nil {
			fmt.Sprintln("输入的M不是整数", err1)
			return
		} else {
			m = mInt
		}
	}

	//可移动的步数
	step := n - m + 1

	mSumList := make([]int, 0)
	//循环步数
	for i := 0; i < step; i++ {
		//获取窗口的slice
		mList := list[i : m+i]
		//计算总和
		mSum := sumOfIntSlice(mList)
		mSumList = append(mSumList, mSum)
		fmt.Println(fmt.Sprintf("窗口和:%d", mSum))
	}

	fmt.Println(fmt.Sprintf("最大窗口和为:%d", maxIntOfSlice(mSumList)))

}
相关推荐
⁤⁢初遇14 分钟前
C语言数据结构---树
数据结构
AI科技星21 分钟前
光速螺旋量子几何统一场论——基于 v ≡ c 公理的四大基本力全维度求导证明与精准数值验证
c语言·开发语言·人工智能·算法·机器学习·平面
ab15151728 分钟前
3.27完成3(指针)、13、41、44(指针)、50、51、95、96、97
算法
AI成长日志40 分钟前
【强化学习专栏】深度强化学习技术演进:DQN、PPO、SAC的架构设计与训练优化
人工智能·算法·架构
郭逍遥44 分钟前
[Godot] JPS跳点寻路和RVO避障
算法·godot·启发式算法
rgb2gray1 小时前
论文详解:基于POI数据的城市功能区动态演化分析——以北京为例
人工智能·算法·机器学习·回归·gwr
m0_734998011 小时前
Day 26
数据结构·c++·算法
信奥卷王1 小时前
2026年03月GESPC++二级真题解析(含视频)
算法
从零开始学习人工智能1 小时前
国产阿特拉斯无人机蜂群核心算法(一)
算法·无人机
golang学习记1 小时前
Go 实时批处理:让数据库少挨点打 [特殊字符]
开发语言·数据库·golang