传入一个数组进行排列,奇数在前升序,偶数在后降序,在程序执行中不能开辟新数组空间
2012-11-15 17:56
756 查看
/** * 传入一个数组进行排列,奇数在前升序,偶数在后降序,在程序执行中不能开辟新数组空间 * @author Administrator * */ public class ArrSortTow { int[] arr={9,3,1,4,5,6,7,8,0,16,11}; static ArrSortTow as; /** * @param args */ public static void main(String[] args) { // TODO Auto-generated method stub as = new ArrSortTow(); for(int i=0;i<as.arr.length;i++){ for(int j=i+1;j<as.arr.length;j++){ if(as.mod(i)&&as.mod(j)) if(!as.compare(i, j))as.sort(i,j); if(!as.mod(i)&&as.mod(j))as.sort(i,j); if(!as.mod(i)&&!as.mod(j)) if(as.compare(i, j))as.sort(i,j); } } } private boolean compare(int i,int j){ if(as.arr[i]>as.arr[j])return false; else return true; } private boolean mod(int i){ if(as.arr[i]%2==0)return false; else return true; } private void sort(int i, int j) { // TODO Auto-generated method stub if(i!=j){ as.arr[i]=as.arr[i]+as.arr[j]; as.arr[j]=as.arr[i]-as.arr[j]; as.arr[i]=as.arr[i]-as.arr[j]; } } }面试中的一道题目
相关文章推荐
- 编写程序,生成一个包含20个随机整数的列表,然后对其中偶数下标的元素进行降序排列,基数下标的元素不变
- java排序,随机生成一个数组,对其进行排序,偶数在前奇数在后,偶数从小到大排,奇数从大到小排
- 给定一个存放整数的数组,重新排列数组使得数组左边为奇数,右边为偶数。 要求:空间复杂度O(1),时间复杂度为O(n)。
- 算法题:将一个数组中所有奇数放前面和偶数放后面(不开辟新的内存空间)
- 4.给定一个存放整数的数组,重新排列数组使得数组左边为奇数,右边为偶数。 要求:空间复杂度O(1),时间复杂度为O(n)
- 有两个升序排列的数组A1和A2,给A1开辟的剩余内存有足够空间容纳A1,请实现一个函数,把A2中所有数字插入到A1中,并且是按照升序排列的
- 有两个升序排列的数组A1和A2,给A1开辟的剩余内存有足够空间容纳A1,请实现一个函数,把A2中所有数字插入到A1中,并且是按照升序排列的
- 有两个升序排列的数组A1和A2,给A1开辟的剩余内存有足够空间容纳A1,请实现一个函数,把A2中所有数字插入到A1中,并且是按照升序排列的
- 有两个升序排列的数组A1和A2,给A1开辟的剩余内存有足够空间容纳A1,请实现一个函数,把A2中所有数字插入到A1中,并且是按照升序排列的
- 有两个升序排列的数组A1和A2,给A1开辟的剩余内存有足够空间容纳A1,请实现一个函数,把A2中所有数字插入到A1中,并且是按照升序排列的
- 给定一个存放整数的数组,重新排列数组使得数组左边为奇数,右边为偶数。要求:空间复杂度O(1),时间复杂度为O(n)
- 有两个升序排列的数组A1和A2,给A1开辟的剩余内存有足够空间容纳A1,请实现一个函数,把A2中所有数字插入到A1中,并且是按照升序排列的
- 有两个升序排列的数组A1和A2,给A1开辟的剩余内存有足够空间容纳A1,请实现一个函数,把A2中所有数字插入到A1中,并且是按照升序排列的
- 有两个升序排列的数组A1和A2,给A1开辟的剩余内存有足够空间容纳A1,请实现一个函数,把A2中所有数字插入到A1中,并且是按照升序排列的
- 有两个升序排列的数组A1和A2,给A1开辟的剩余内存有足够空间容纳A1,请实现一个函数,把A2中所有数字插入到A1中,并且是按照升序排列的
- 将一个整形数组奇数排列在前偶数排列在后
- 有两个升序排列的数组A1和A2,给A1开辟的剩余内存有足够空间容纳A1,请实现一个函数,把A2中所有数字插入到A1中,并且是按照升序排列的
- 有两个升序排列的数组A1和A2,给A1开辟的剩余内存有足够空间容纳A1,请实现一个函数,把A2中所有数字插入到A1中,并且是按照升序排列的
- 百度笔试:给定一个存放整数的数组,重新排列数组使得数组左边为奇数,右边为偶数。 要求:空间复杂度O(1),时间复杂度为O(n)
- 有一个字符数组的内容为:"student a am i",请你将数组的内容改为"i am a student". 要求: 不能使用库函数。只能开辟有限个空间(空间个数和字符串的长度无关)。