weixin_55317608
2021-02-18 11:05
采纳率: 80%
浏览 47

c++ 重排数组的问题 请大虾帮助

要求结果为19 15 7 11 9 32 54 88 100 10

#include<iostream>

using namespace std;

int main()

{

int m[]={10,15,32,11,9,7,54,88,100,19};

int *ps=m,*pe=m+sizeof(m)/sizeof(int),t,i;

for(i=0;i<sizeof(m)/sizeof(int);i++)

cout<<m[i]<<" ";

cout<<endl;

while(          )

{

while((*ps)%2!=0 && ps<pe)

           ;

while(           && ps<pe)

           ;

t=*ps;

*ps=*pe;

*pc=t;

}

for(i=0;i<sizeof(m)/sizeof(int);i++)

cout<<m[i]<<" ";

cout<<endl;

return 0;

}

  • 写回答
  • 关注问题
  • 收藏
  • 邀请回答

2条回答 默认 最新

  • 青山千秋画 2021-02-18 14:53
    已采纳

    while(      ps<pe    ) //终止条件

    {

    while((*ps)%2!=0 && ps<pe) //从后往前查找非偶数

          ps++     ;

    while(   (*pe)%2==0   && ps<pe) //从前往后查找偶数

           pe--    ;

    t=*ps;

    *ps=*pe;

    *pe=t;

    }

     

    打赏 评论
  • SoftwareTeacher 2021-02-18 13:26

    int m[]={10,15,32,11,9,7,54,88,100,19};

    要求结果为19 15 7 11 9 32 54 88 100 10

    这是根据什么规律的重组啊? 奇偶数互换位置? 

    打赏 评论

相关推荐 更多相似问题