为什么java在自己这是正确的但过不了oj_技术角 | 记一次OJ测试赛算法实现思路...

80f6a51460457a3dd649cdc6b4cef9af.png点击上方 “慧响” 可以订阅哦!

本文字数:1168字

阅读时间:3分钟

89d930bda1a6fa904f981ea53be2af3b.png今下午一个小时三道题的OJ测试赛告一段落。首先一首《凉凉》送给自己。整天工作CRUD以及近期代码几乎没碰,再加上OJ刷题的日子已经过去五年了,导致犯了好几个傻瓜的基础错误,浪费了原本就宝贵的时间。题二原本估计能拿一半分的(如果后台样例形式在我估计之中的话)。现就测试赛三题中的前两题进行算法实现思路的整理。首先是本文中题目并不是原封不动的摘抄,这里只对关键要求进行回忆和描述,同时为了避免不必要的麻烦,因此题目描述进行了一定变形,但基本逻辑一致。另外我的思路不一定是正确和最优的,欢迎留言讨论。 使用语言:Java。编译器可使用标准类以及java.util.*类。题一:数组与遍历 题目描述:一家公司有n个营业点,编号从1到n,每次会对第i个营业点到第j个营业点供应m个货物。现有多条供货记录放置在一个二维数组里。假如有5个营业点,供货记录如下:[[1,2,10],[2,3,30],[2,5,60]]。程序需要计算出每个供货点接到的货物个数,本例返回结果应为[10,100,90,60,60]。二维数组大小、营业点个数有最高限制(不过我记得不深了,忘记是5000000还是50000000了),0<i<j<n。 解题思路:本题形参表第一个为供货记录,二维数组;第二个为营业点个数,int型。本题很简单,简单的思路就是在二维数组遍历前建好以营业点为数量的一维数组。后遍历二维数组,再取第二层数组信息依次作为i,j,m,建循环由i到j,作为一维数组的下标,并加m进该一维数组元素中。本题唯一注意的地方是自建一维数组下标。数组下标是0开头,n-1为最后一个。题二:字符串 题目描述:根据所输入字符串进行还原。例如样例WOSHINI[2BA],程序应该返回WOSHINIBABA。如样例[3WO]SHINI[2BA],应返回WOWOWOSHINIBABA。样例有嵌套的情况,例如WOSHI[3NI[2BA]],则应该是WOSHINIBABANIBABANIBABA。程序样例给出的嵌套不多于10层。 解题思路:我这题当时做的时候没考虑嵌套情况。其实就是将字符串拆为字符,通过遍历判断中括号范围进行预先拼接,后与无括号部分进行最终拼接。本来寻思这个题后面样例再怎么说有两三个非嵌套的吧……但是根据提交成绩来看好像就一个……另外这个题的弱智问题犯得太多了,不是丢int声明就是char转int的时候忘了根据ASCII码进行-'0',尤其是最后这个错误,愣是查了半天代码才看出来这个错。改过来的时候就剩10分钟了……真的闹心啊……数据结构、算法和ACM学的东西全还给杨老师、沙老师和寰哥了……日了狗了……目测此题也可以通过栈和递归实现。欢迎大佬给本蒟蒻分享方法。题三:树由于时间有限,这个题没有时间看和做了。好像是个最小生成树问题。有心人可以在留言区评论。

于这是测试赛,题目并不怎么难……这么看来正式赛专业组已经凉透了,只能大众组求虐了……做成这个熊样真的很暴露问题,以此为契机,计划每天做几个题,多刷刷LeetCode吧。

雁过留名 请记得点击

在看

分享文章哦~

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值