将一个有n个非零元素的整数一维数组a[n]拆分为两个一维数组,使得a[]中大于0的元素存放在b[]中,小于0的元素存放在c[]中。

殷人昆版数据结构c++版 勘误

不知道有木有做过这些 真的是太折磨人惹,刚刚开始看教材发现好容易有错,腊鸡我斗看出来惹。哎准备把我遇到所有的错误整理出来,希望大家不要踩坑。我想多花些时间想做些有意义的事情。

习题2-8
将一个有n个非零元素的整数一维数组a[n]拆分为两个一维数组,使得a[]中大于0的元素存放在b[]中,小于0的元素存放在c[]中。

pa,pb用引用的方式传递其结果。

#include <iostream>
#include <stdlib.h>

void fenjie(int A[],int B[],int C[],int n,int &pb,int &pc)
{
    pb=pc=-1;
    for (int k=0;k<n;k++) {
        if (A[k] > 0)
            B[++pb] = A[k];
        else C[++pc]=A[k];
    }
}
int main() {
    int pb;
    int pc;
    int n=7;
    int A[]={1,-1,2,3,-4,7,8};
    int B[10];
    int C[10];
  fenjie(A,B,C,n,pb,pc);
    for(int i=0;i<pb+1;i++){
        std::cout<<B[i]<<std::endl;
    }
    for(int i=0;i<pc+1;i++){
        std::cout<<C[i]<<std::endl;
    }

    return 0;
}

说明:教材中 while (int k=0;k<n;k++)是❌的。
应该改为for (int k=0;k<n;k++)

over~

  • 2
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值