Leetcode每日一题_18
&nbsp;&nbsp;&nbsp;&nbsp;public&nbsp;List<List<Integer>>&nbsp;fourSum(int[]&nbsp;nums,&nbsp;int&nbsp;target)&nbsp;{
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;List<List<Integer>>&nbsp;ans&nbsp;=&nbsp;new&nbsp;ArrayList();
int&nbsp;len&nbsp;=&nbsp;nums.length;
Arrays.sort(nums);

if&nbsp;(nums&nbsp;==&nbsp;null&nbsp;||&nbsp;len&nbsp;<&nbsp;4)
return&nbsp;ans;

for&nbsp;(int&nbsp;i&nbsp;=&nbsp;0;&nbsp;i&nbsp;<&nbsp;len&nbsp;-&nbsp;3;&nbsp;i++)&nbsp;{
if&nbsp;(i&nbsp;>&nbsp;0&nbsp;&&&nbsp;nums[i]&nbsp;==&nbsp;nums[i&nbsp;-&nbsp;1])
continue;
for&nbsp;(int&nbsp;j&nbsp;=&nbsp;i&nbsp;+&nbsp;1;&nbsp;j&nbsp;<&nbsp;len&nbsp;-&nbsp;2;&nbsp;j++)&nbsp;{
if&nbsp;(j&nbsp;>&nbsp;i&nbsp;+&nbsp;1&nbsp;&&&nbsp;nums[j]&nbsp;==&nbsp;nums[j&nbsp;-&nbsp;1])
continue;
int&nbsp;L&nbsp;=&nbsp;j&nbsp;+&nbsp;1;
int&nbsp;R&nbsp;=&nbsp;len&nbsp;-&nbsp;1;

while&nbsp;(L&nbsp;<&nbsp;R)&nbsp;{
int&nbsp;sum&nbsp;=&nbsp;nums[i]&nbsp;+&nbsp;nums[j]&nbsp;+&nbsp;nums[L]&nbsp;+&nbsp;nums[R];

if&nbsp;(sum&nbsp;==&nbsp;target)&nbsp;{
ans.add(Arrays.asList(nums[i],&nbsp;nums[j],&nbsp;nums[L],&nbsp;nums[R]));
while&nbsp;(L&nbsp;<&nbsp;R&nbsp;&&&nbsp;nums[L]&nbsp;==&nbsp;nums[L&nbsp;+&nbsp;1])
L++;
while&nbsp;(L&nbsp;<&nbsp;R&nbsp;&&&nbsp;nums[R]&nbsp;==&nbsp;nums[R&nbsp;-&nbsp;1])
R--;
L++;
R--;
}&nbsp;else&nbsp;if&nbsp;(sum&nbsp;>&nbsp;target)
R--;
else&nbsp;if&nbsp;(sum&nbsp;<&nbsp;target)
L++;

}
}
}
return&nbsp;ans;
&nbsp;&nbsp;&nbsp;&nbsp;}
全部评论

相关推荐

面了这么多场试,总有公司总喜欢压力面一个小时面试+手撕,哪里不会就点哪里,说了不会不会还继续追着问不尊重求职者,稍微有些细节记不清了,就开始怀疑项目真实性以及人格让求职者开摄像头但是自己不开,说话声音还贼小,pardon几次就开始不耐烦的不知道这个算不算,手撕的时候,面试官人跑了。。。最后快结束才来
一纸丿繁华丶:你换位思考一下,自己在职场被领导push麻了,身心俱疲,现在有个机会让你放松一下,体验一把上位者的感觉,还能看着那些高学历人才、未来自己的竞争者,抓耳挠腮、手足无措的样子,没给你当场笑出来就不错了,理解一下面试官吧。
点赞 评论 收藏
分享
评论
1
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务