给一个数组,使奇数在前偶数在后,不能改变相对位置
来源:互联网 发布:php在线帮助文档系统 编辑:程序博客网 时间:2024/06/14 03:22
题目:
输入一个整数数组,实现一个函数来调整该数组中数字的顺序,使得所有的奇数位于数组的前半部分,所有的偶数位于位于数组的后半部分,并保证奇数和奇数,偶数和偶数之间的相对位置不变。
思路:可以再建立一个数组,第一遍处理基数,放在另一个数组的前面,再来一遍处理偶数,接着放。然后再复制。
部分代码:
public void reOrderArray(int [] array) {
int [] array1 = new int[array.length];
int index = 0;
for(int i = 0;i<array.length;i++){
if(array[i] % 2!=0){ //先处理奇数
array1[index] = array[i];
index++;
}
}
for(int i = 0;i<array.length;i++){
if(array[i]%2==0){ //再处理偶数
array1[index] = array[i];
index++;
}
}
for(int i = 0;i<array.length;i++){
array[i] = array1[i];
}
}
说明:我之前再第三个for循环那儿,没有for循环,直接写的是array = array1;
然后我在这个函数最底下逐个输出array,然后根据结果是处理之后的结果,但是在main函数里面输出的是原来的数组。
这是为什么呢?
key:数组类型这个是传递的是引用,当array = array1;是指让array指向array1的位置,但是array本身并没有改变,跟别说是array里面的值。
再举个例子:
public static void main(String[] args) {
// TODO Auto-generated method stub
String aline = "I am a";
String bline = aline;
aline = "I am b";
System.out.println(bline);
}
这个代码的输出是什么呢?到底是 I am a还是I am b呢?
解析:
定义aline指向的是常量里面的“I am a”的位置,然后 定义bline是让它指向a指向的位置,也就是常量里面的“I am a”的位置,之后再令aline指向
“I am b”的位置,但是并没有改变bline指向的位置,所以bline的值就是。。。
key: I am a
说明:传递的如果是引用,那么就相当于是C/C++的指针,如果是值传递,那么就是值的复印件。
- 给一个数组,使奇数在前偶数在后,不能改变相对位置
- 将一个整形数组奇数排列在前偶数排列在后
- 剑指_调整数组顺序使奇数在前偶数在后
- 数组排序,奇数在前偶数在后
- 整数数组,奇数在前,偶数在后
- 题目:数组排序 奇数在前 偶数在后
- 有序数组:>奇数在前 偶数在后
- 数组排序,奇数在前,偶数在后
- 奇数在前偶数在后
- 传入一个数组进行排列,奇数在前升序,偶数在后降序,在程序执行中不能开辟新数组空间
- 奇数在前 偶数在后,相对顺序保持不变
- 奇数在前,偶数在后,可以有顺序改变
- 数组:调整一个数组,把奇数放在前半部分,偶数在后半部分
- java排序,随机生成一个数组,对其进行排序,偶数在前奇数在后,偶数从小到大排,奇数从大到小排
- 对一个整型数组做奇数在前偶数在后的顺序调整
- 数组:奇数在前,偶数在后,要求顺序不变
- 将数组中元素排列为奇数在前偶数在后
- 数组排序,奇数在前,偶数在后(二)
- 成为Java顶尖程序员 ,看这11本书就够了
- 图片(文件)上传
- MySQL mysqldump 导入/导出 结构&数据&存储过程&函数&事件&触发器
- jacob学习一:向word中添加一个字符串
- 51Nod-1355-斐波那契的最小公倍数
- 给一个数组,使奇数在前偶数在后,不能改变相对位置
- Vue—— 组件进阶
- static关键字
- TCP/IP协议分层详解
- git使用时遇到 '/path/my_project/.git/index.lock: File exists'
- 初识插件化
- OpenGL超级宝典Windows + VS2013开发环境配置
- Google分析统计
- 2.RPC框架的简单实现(定义自己的ldubbo命名空间)