【手把手带你刷好题】—— 39.按奇偶排序数组(双指针)

举报
安然无虞 发表于 2022/05/27 00:53:04 2022/05/27
【摘要】 【前言】 今天是刷题打卡第39天! 不负代码不负卿,向前冲。 原题:按奇偶排序数组(双指针)  题目描述: 输入一个长度为 n 整数数组,数组里面不含有相同的元素,实现一个函数来调整该数组中数字的顺序,使得所有的奇数位于数组的前面部分,所有的偶数位于数组的后面部分,并保证奇数和奇数,偶数和偶数之...

【前言】

今天是刷题打卡第39天!

不负代码不负卿,向前冲。

原题:按奇偶排序数组(双指针) 

题目描述:

输入一个长度为 n 整数数组,数组里面不含有相同的元素,实现一个函数来调整该数组中数字的顺序,使得所有的奇数位于数组的前面部分,所有的偶数位于数组的后面部分,并保证奇数和奇数,偶数和偶数之间的相对位置不变。

示例:


  
  1. 输入:[1,2,3,4]
  2. 返回值:[1,3,2,4]

方法一:模拟

https://blog.csdn.net/weixin_57544072/article/details/121548594https://blog.csdn.net/weixin_57544072/article/details/121548594icon-default.png?t=LA92https://blog.csdn.net/weixin_57544072/article/details/121548594方法二:双指针

思路:

定义两个指针,一个从头找偶数,一个从尾找奇数。

代码执行:


  
  1. #include<stdio.h>
  2. void print(int* arr, int sz)
  3. {
  4. int i = 0;
  5. for (i = 0; i < sz; i++)
  6. {
  7. printf("%d ", arr[i]);
  8. }
  9. printf("\n");
  10. }
  11. void move(int* arr, int sz)
  12. {
  13. int* left = arr;
  14. int* right = arr + sz - 1;
  15. while (left < right)
  16. {
  17. //从左边找偶数,停下
  18. while ((left < right) && (*left) % 2 == 1)//注意:一定要在循环中加上left<right这个条件,否则当数组全是奇数时导致越界
  19. {
  20. left++;
  21. }
  22. //从右边找奇数,停下
  23. while ((left < right) && (*right) % 2 == 0)//注意:一定要在循环中加上left<right这个条件,否则当数组全是偶数时导致越界
  24. {
  25. right--;
  26. }
  27. if (left < right)//要加上判断条件哦,不能一直交换,left>=right时就不需要交换了
  28. {
  29. int temp = *left;
  30. *left = *right;
  31. *right = temp;
  32. }
  33. }
  34. }
  35. int main()
  36. {
  37. int arr[10] = { 1,2,3,4,5,6,7,8,9,0 };
  38. int sz = sizeof(arr) / sizeof(arr[0]);
  39. print(arr, sz);
  40. move(arr, sz);
  41. print(arr, sz);
  42. return 0;
  43. }

结语

今天是刷题打卡第39天!

加油吧少年。

文章来源: bit-runout.blog.csdn.net,作者:安然无虞,版权归原作者所有,如需转载,请联系作者。

原文链接:bit-runout.blog.csdn.net/article/details/121711061

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。