正数放右边,负数放左边 —— java

这篇博客讲述了作者的朋友在面试中遇到的一个Java编程问题:如何不通过排序将数组中的负数移动到左边,正数移动到右边。面试官拒绝了使用额外数组的解决方案,并给了10分钟时间思考。作者尝试了遍历并交换位置的方法,但遇到了问题,意识到在Java中值传递的理解不足,决定加强这方面知识的学习。
摘要由CSDN通过智能技术生成

今晚队伍里的一名技术成员面试北京一家创业公司,逼格挺高,都是阿里微软出来的高管创业,面java研发岗位。

问了一个问题,一个数组,里面的数字比较乱,要求负数放左边,正数放右边。

= = 结果他没答上来。。。

他选择再开两个数组,正数放进去,负数放进去。

面试官要求不能用排序,觉得排序复杂度太高。


给了10分钟时间,我听完后也试了一下题目,这是一开始写的算法

扫描遍历,发现正数出现在负数前面,就调换位置。

按理说挺简单,两分钟就写完了,但是跑不出结果。

一开始以为是死循环,后面测试发现swap函数没起啥作用。

于是改了一下,这是新的代码:

package edu.fjnu.method;

public class Method {

	
	public int[] arrayChange(int [] array){
		int length = array.length ;
		int low = 0;
		int high = length -1 ;
		
		while (low <high) {
			while(array[low]<0 && low <
  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值