华为机试题(7)

本文介绍了一个C++程序,该程序能够实现对数组中奇数和偶数分别进行排序的功能,并将排序后的奇数和偶数交叉放置。文章通过具体代码展示了如何实现这一功能。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

对一个数组,将数组中偶数从大到小排序,奇数从小到大排序,奇数和偶数交叉着放且输出数组第一位放奇数

若奇数和偶数不等长,则把剩下的直接放到数组中。

  1. #include<stdio.h>
  2. #include<stdlib.h>
  3. #include<string.h>
  4. voidsorts(inta[],intn)
  5. {
  6. inti,j;
  7. inttmp;
  8. intcnt0=0,cnt1=0;
  9. intcnt2;
  10. /*intmax_ou,min_ji;*/
  11. intou_num=0,ji_num=0;
  12. int*r=a;
  13. intou_arr[100]={0};
  14. intji_arr[100]={0};
  15. int*p_ou=ou_arr;
  16. int*p_ji=ji_arr;
  17. int*p=ou_arr;
  18. int*q=ji_arr;
  19. for(i=0;i<n;i++)
  20. {
  21. if(a[i]%2==0)//偶数
  22. {
  23. ou_num++;
  24. *p_ou++=a[i];
  25. }
  26. else//奇数
  27. {
  28. ji_num++;
  29. *p_ji++=a[i];
  30. }
  31. }
  32. printf("ou_num=%d\n",ou_num);
  33. printf("ji_num=%d\n",ji_num);
  34. printf("beforesortedoushunumis:");
  35. for(i=0;i<ou_num;i++)
  36. printf("%d",ou_arr[i]);
  37. printf("\n");
  38. printf("beforesortedjishunumis:");
  39. for(i=0;i<ji_num;i++)
  40. printf("%d",ji_arr[i]);
  41. printf("\n");
  42. //偶数从大到小排列
  43. for(i=0;i<ou_num-1;i++)
  44. for(j=i+1;j<ou_num;j++)
  45. if(ou_arr[i]<ou_arr[j])
  46. {
  47. tmp=ou_arr[i];
  48. ou_arr[i]=ou_arr[j];
  49. ou_arr[j]=tmp;
  50. }
  51. printf("sortedoushunumis:");
  52. for(i=0;i<ou_num;i++)
  53. printf("%d",ou_arr[i]);
  54. printf("\n");
  55. //奇数从小到大排列
  56. for(i=0;i<ji_num-1;i++)
  57. for(j=i+1;j<ji_num;j++)
  58. if(ji_arr[i]>ji_arr[j])
  59. {
  60. tmp=ji_arr[i];
  61. ji_arr[i]=ji_arr[j];
  62. ji_arr[j]=tmp;
  63. }
  64. printf("sortedjishunumis:");
  65. for(i=0;i<ji_num;i++)
  66. printf("%d",ji_arr[i]);
  67. printf("\n");
  68. while(cnt0<ji_num&&cnt1<ou_num)
  69. {
  70. *r++=*q++;
  71. cnt0++;
  72. *r++=*p++;
  73. cnt1++;
  74. }
  75. cnt2=cnt1;
  76. if(cnt0==ji_num)
  77. {
  78. while(cnt1<ou_num)
  79. {
  80. *r++=*p++;
  81. cnt1++;
  82. }
  83. }
  84. if(cnt2==ou_num)//这个地方有问题
  85. {
  86. while(cnt0<ji_num)
  87. {
  88. *r++=*q++;
  89. cnt0++;
  90. }
  91. }
  92. }
  93. intmain(/*intargc,char**argv*/)
  94. {
  95. inti;
  96. inta[14]={2,0,3,9,4,10,7,11,15,22,66,31,21,87};
  97. sorts(a,14);
  98. for(i=0;i<14;i++)
  99. printf("%d",a[i]);
  100. getchar();
  101. return0;
  102. }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值