2021-06-26 16:20 采纳率: 100%
浏览 239
已采纳

合并两个有序顺序表为一个有序顺序表时结果出现-842150451

#include<iostream>

using namespace std;

//动态分配

#define InitSize 100   

typedef int ElemType; 

typedef struct {

     ElemType *data; 

     int length; 

      int MaxSize; 

}SeqList;

 

//顺序表初始化

void InitList(SeqList &L) {

  L.data = new ElemType[InitSize];

  if(!L.data) {

     cout<<"存储空间申请失败!";

  return;

  }

     L.length = 0; 

  L.MaxSize = InitSize;

}

//合并两个有序顺序表

bool Merge(SeqList A,SeqList B,SeqList &C) {

     if(A.length + B.length > C.MaxSize)

   return false;

  int i = 0,j = 0,k = 0;

  while(i < A.length && j < B.length) {

      if(A.data[i] <= B.data[j])

             C.data[k++] = A.data[i++];

   else

    C.data[k++] = B.data[j++];

  }

  while(i < A.length) 

         C.data[k++] = A.data[i++];

     while(j < B.length) 

         C.data[k++] = B.data[j++];

     C.length = k;

  return true;

}

//遍历并打印顺序表

void PrintList(SeqList L) {

   for (int i =0;i <L.length;i ++)

        cout <<L.data [i]<<" ";

   cout <<endl;

}

void main(){

    SeqList A;

    InitList(A);

    SeqList B;

    InitList(B);

    SeqList C;

    InitList(C);

    A.length = 4;

    B.length = 5;

    C.length = A.length + B.length;

    cout<<"打印A有序表:"<<endl;

    for(int i = 0;i < A.length;i++) {

    A.data[i] = 2 * i + 1;

    }

    PrintList(A);

    cout<<"打印B有序表:"<<endl;

    for(int j = 0;j < B.length;j++) {

         A.data[j] = 2 * (j+1);

    }

    PrintList(B);

    cout<<"打印合并顺序表C:"<<endl;

    if(Merge(A,B,C))

         PrintList(C);

}

运行结果如下图所示

如何解决,求大佬告知

  • 写回答

1条回答 默认 最新

  • CSDN专家-link 2021-06-26 16:22
    关注

    乱码时指针值吧,写急了吧,A,B写混了

      for(int j = 0;j < B.length;j++) {

             A.data[j] = 2 * (j+1);

    这里应该时B.data[j] = 2*(j+1)啊,把改写到B的写入A了,B等于啥也没有

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥500 火焰左右视图、视差(基于双目相机)
  • ¥100 set_link_state
  • ¥15 虚幻5 UE美术毛发渲染
  • ¥15 CVRP 图论 物流运输优化
  • ¥15 Tableau online 嵌入ppt失败
  • ¥100 支付宝网页转账系统不识别账号
  • ¥15 基于单片机的靶位控制系统
  • ¥15 真我手机蓝牙传输进度消息被关闭了,怎么打开?(关键词-消息通知)
  • ¥15 装 pytorch 的时候出了好多问题,遇到这种情况怎么处理?
  • ¥20 IOS游览器某宝手机网页版自动立即购买JavaScript脚本