如何使用数组和指针在C++中实现插入排序算法?

Jik*_*ika 2 c++ arrays pointers

我正在尝试学习C++,数组和指针.我决定实现插入排序算法.所以,这是我的代码和错误的输出.我该怎么做才能纠正它?你能否告诉我我的错误是什么?如果这是一个常见的错误我应该避免什么?

我的代码:

// InsertionSort.cpp

#include "stdafx.h"
#include <iostream>

int DeclareAnInteger();
int* DeclareAndShowTheArray(int n);
int* InsertionSort(int *A, int n);

int main()
{

   int n = DeclareAnInteger();
   int *A;
   A = DeclareAndShowTheArray(n);
   int *B;
   B = InsertionSort(A, n);

   system("PAUSE");
   return 0;
}

int DeclareAnInteger()
{
   int n;
   std::cout << "Please enter a positive integer n: ";
   std::cin >> n;
   return n;
}

int* DeclareAndShowTheArray(int n)
{
   int *A;
   A = (int *)alloca(sizeof(int) * n);
   for (int i = 0; i < n; i++)
   {
      std::cout << "Please enter the value of A[" << i + 1 << "]: ";
      std::cin >> A[i];
   }
   std::cout << "The unsorted array is: ";
   for (int i = 0; i < n; i++)
   {
      std::cout << A[i];
      std::cout << "\t";
   }
   std::cout << "\n";
   return A;
}

int* InsertionSort(int *A, int n)
{
   int k;
   //int *A = new int[n];
   for (k = 1; k < n; k++)
   {
      int key = A[k];
      int m   = k - 1;
      while (m >= 0 & A[m] > key)
      {
         A[m + 1] = A[m];
         m        = m - 1;
      }
      A[m + 1] = key;
   }
   std::cout << "The sorted array is: ";
   for (int i = 0; i < n; i++)
   {
      std::cout << A[i];
      std::cout << "\t";
   }
   std::cout << "\n" << std::endl;
   return A;
}
Run Code Online (Sandbox Code Playgroud)

我的输出: 在此输入图像描述

Som*_*ude 9

这是一个很大的问题:

A = (int *)alloca(sizeof(int) * n);
Run Code Online (Sandbox Code Playgroud)

alloca函数分配在堆栈上,而当函数返回给你一个迷失指针,它将会丢失不确定的行为,当你解引用这个指针.

如果您正在编程C++然后使用new,如果您编程C然后使用malloc.