当前位置: 首页 > news >正文

华为机考练习(golang)

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

package mainimport ("bufio""fmt""os""strconv""strings"
)func sumOfIntSlice(list []int) int {sum := 0for _, i := range list {sum += i}return sum
}func maxIntOfSlice(list []int) int {max := 0for _, 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 + 1mSumList := make([]int, 0)//循环步数for i := 0; i < step; i++ {//获取窗口的slicemList := list[i : m+i]//计算总和mSum := sumOfIntSlice(mList)mSumList = append(mSumList, mSum)fmt.Println(fmt.Sprintf("窗口和:%d", mSum))}fmt.Println(fmt.Sprintf("最大窗口和为:%d", maxIntOfSlice(mSumList)))}

http://www.lryc.cn/news/446918.html

相关文章:

  • 51单片机快速入门之按键应用拓展
  • 数据库 - MySQL的事务
  • 【Python机器学习】NLP信息提取——提取人物/事物关系
  • vector类
  • python常见的魔术方法
  • 自动化测试常用函数:弹窗、等待、导航、上传与参数设置
  • 【必看】2024国赛选题分布情况分析及数模国赛答辩指南~答辩不走弯路
  • 微服务注册中⼼1
  • 我设置了路由器自动切换ip,这会让我的账号登录地址经常改变吗
  • Nginx 限流实战教程和技巧
  • AlphaFold3 | 详解 AlphaFold3 的模型结构及其在不同类型的预测实验中的表现
  • 公交IC卡收单管理系统 多处 SQL注入致RCE漏洞复现
  • 淘客系统开发之卷轴模式系统源码功能分析
  • MoCo中的字典
  • Xcode16 iOS18 编译问题适配
  • 加密解密的艺术:探索Java中的DES算法
  • jQuery——层次选择器
  • MySQL常见面试总结
  • 记录一次学习--委派攻击学习
  • 前端列表数据太多导致页面卡顿就这么处理
  • 机器学习_神经网络_深度学习
  • MT6765/MT6762(R/D/M)/MT6761(MT8766)安卓核心板参数比较_MTK联发科4G智能模块
  • TikTok五分钟开户快速步骤流程!
  • BFS 解决拓扑排序 , 课程表 , 课程表 II , 火星词典
  • web安全攻防渗透测试实战指南_web安全攻防渗透测试实战指南,零基础入门到精通,收藏这一篇就够了
  • 大模型如何赋能智慧城市新发展?
  • 随记——机器学习
  • 【在Linux世界中追寻伟大的One Piece】进程间通信
  • 多路复用IO
  • C++ prime plus-7-編程練習