华为笔试感觉很凉

华为题不难,但是不太会用Scanner,在输入那里卡了好久,时间不够都#华为##笔试题目#
全部评论
写代码10分钟,用异常处理输入1小时
点赞 回复 分享
发布于 2019-04-03 21:25
一般oj都是不断输入用例的,所以不用判断结束,不影响写代码的吧,就按照他一直在输入的状态,把输入的数据按照你想要的逻辑存起来,之后再处理应该就可以。如果你写的是: while(sc.hasNext()){} 的话,用例测试的时候它会自己用一个表示输入结束的动作的(一般是ctrl+z),你可以在本地IDE测试一下。 笔试第一题,考试的时候脑子短路,后来想了想,可能是这样的,在本地测试是可行的,贴出来大家一起讨论一下~~~~(我这个就是输入ctrl+z表示输入结束的,之前在牛客上做了几道题都是这样的,我猜系统测试的时候会有表示输入结束的提示,不用我们判断吧) 题设大概:给定n个数组,合并成一个数组。合并逻辑为:第一行输入一个整数k,为每次从数组取出的最大元素个数,第2-n行为需要合并的数组,每次从一行的数组读取k个元素,并将这k个元素从行数组中删掉,跳到下一行,直到没有下一行,再从第一行开始读入K个元素,循环往复。 eg: 输入 3 2,5,6,7,9,5,7 1,7,4,3,4 输出: 2,5,6,1,7,4,7,9,5,3,4,7 代码如下: import java.util.*; public class Main2 {     public static void main(String[] args) {         //我这里用StringBuffer记录一行         StringBuffer result=new StringBuffer(),temstr=null;         List<StringBuffer> tem=new LinkedList<>();         Scanner sca=new Scanner(System.in);         int n=sca.nextInt();         String temp=null;String[] split=null;         while(sca.hasNext()){             temp=sca.nextLine();             temstr=new StringBuffer();             split=temp.split(",");             for(int i=0;i<split.length;i++)                 temstr.append(split[i]);             tem.add(temstr);         }         while(tem.size()!=0){             for(int i=0;i<tem.size();i++){                 temstr=tem.get(i);                 if(temstr.length()>n) {                     result.append(temstr.substring(0, n));                     temstr.delete(0,n);                 }                 else{                     result.append(temstr.toString());                     tem.remove(i);                     i--;                 }             }         }         sca.close();         for(int i=0;i<result.length();i++) {             System.out.print(result.toString().charAt(i)+",");             if(i==result.length()-1) {                 System.out.print(result.toString().charAt(i));             }         }     } } 希望大家纠错探讨~~~
点赞 回复 分享
发布于 2019-04-05 00:15
我判断两个回车表示结束,本地怎么都ok,结果还是0%
点赞 回复 分享
发布于 2019-04-03 21:08
唉,搞了半天都不知道咋输入的,只有60%。
点赞 回复 分享
发布于 2019-04-03 21:11
直接看例子,while(scanner.hasNext()){..}
点赞 回复 分享
发布于 2019-04-03 21:16
使用C++输入是这样的 while(cin >> str) { }它这里的样例应该是放在一个文件中,cin输入流对接的是对应的那个文件流,当有字符串读取时cin>>str会读取成功,当读到文件末尾时cin>>str会返回一个null,这样while循环就结束了。
点赞 回复 分享
发布于 2019-04-03 21:18
这个输入怎么判结束啊,好难受
点赞 回复 分享
发布于 2019-04-03 21:07
哎,完全一样的感受,我现在都不明白怎么判断输入结束,同Scanner
点赞 回复 分享
发布于 2019-04-03 21:08
第二题也凉了。。
点赞 回复 分享
发布于 2019-04-03 21:10
为什么用idea复制数据进去,获得数据为空
点赞 回复 分享
发布于 2019-04-03 21:13
python捕获异常
点赞 回复 分享
发布于 2019-04-03 21:14
while(sc.hasnextline()),本地调试无法结束,我本地调试就写死成几次循环,但是提交的时候这么写能过
点赞 回复 分享
发布于 2019-04-03 21:16
这给题的输入也太难获取了吧。
点赞 回复 分享
发布于 2019-04-03 21:22
lines = sys.stdin.readlines() python使用这个函数可以吗?
点赞 回复 分享
发布于 2019-04-03 21:29
import sys def paixu(key,array): result=[] aaa=[] changdu=0 n=len(array) for i in range(n): changdu+=len(array[i]) while len(aaa)<changdu: for j in range(n): if len(array[j])<key: result.append(array[j][0:]) del array[j][0:] else: result.append(array[j][0:key]) del array[j][0:key] aaa=[] for i in result: aaa.extend(i) RRR=[] for i in result: RRR.extend(i) return RRR if __name__ == "__main__": key = int(input()) array = [] while 1: try: array.append(list(map(int, input().split(',')))) except: break #print(paixu(key, array)) A=paixu(key,array) A = ','.join(('%s' %i for i in A)) print(A)
点赞 回复 分享
发布于 2019-04-03 21:52
本人已凉凉😂
点赞 回复 分享
发布于 2019-04-04 08:11
华为笔试不刷人,放心
点赞 回复 分享
发布于 2019-04-04 09:51
有木有人感觉华为这题出的有点难理解的,尤其是昨天的第二题,题目描述里面说的意思跟测试样例的输入输出的意思不符,我看第二题看了好多遍,最后结果也还是不对,而且我竟然运行空间超限了,我了个去,第一次遇到这情况,根据题的意思就是一个合法字符串和一个非法字符串嘛,其他的也没啥呀,怎么就超限了,真是百思不得其解😪
点赞 回复 分享
发布于 2019-04-04 09:54
其实不需要判断有多少输入, 只需要在你觉得输入完的时候, 按下 ctrl + D 就可以了。。 牛客上面是用文件做读入的,自己就有 EOF 标志。
点赞 回复 分享
发布于 2019-04-04 11:18
请问像这次笔试第一题这样的输出是不是结尾还要加回车符
点赞 回复 分享
发布于 2019-04-04 17:32

相关推荐

有没有经济学家能告诉我,三年后中国的就业市场会不会好转?我在校招中拿到了一份9k+的offer,还是行业的龙头企业,心里其实不想再考研了。但又总是担心,万一读研后薪资更高,我会不会后悔呢?
Fyhyuky:三年后肯定不会啊,只会比现在更烂,你自己看看现在有没有什么增长点,电车都是国家补贴兜底才发展出来的,已经比较违背市场自然规律了,互联网更不用说了,国家强力打压,传统制造业转型失败,现在苟延残喘中
点赞 评论 收藏
分享
10-15 09:13
已编辑
天津大学 soc前端设计
点赞 评论 收藏
分享
点赞 评论 收藏
分享
点赞 19 评论
分享
牛客网
牛客企业服务