C++中用动态分配内存来改变数组长度

编写一个程序,输入n个数,然后对这n个数进行排序。输多少个数字由n确定,然后把数字依次放入数组中进行排序,定义了怎么调用也讲下,高手来哦!... 编写一个程序,输入n个数,然后对这n个数进行排序。输多少个数字由n确定,然后把数字依次放入数组中进行排序,定义了怎么调用也讲下,高手来哦! 展开
 我来答
匿名用户
2013-10-20
展开全部
C++嘛 当然要用new 和delete了直接给你代码吧 按你要求写了个 #include<iostream>
using namespace std;void display( int *tmp, int size );//显示
void sort( int *tmp,int size );//排序int main()
{
int n;
cout << "输入一个整数:";
cin >> n;
int * test = new int[n];
for ( int i = 0; i < n; i++ )
{
cout << "输入第" << i+1 << "个数:";
cin >> test[i];
} cout << "输出排序前的数组:" << endl;
display( test,n);
sort( test,n );
cout << "输出排序后的数组:" << endl;
display( test,n); delete [] test;
return 0;
}void display( int *tmp, int size )
{
for ( int i = 0; i < size; i++ )
{
cout << tmp[i] << ",";
}
cout << endl;
}void sort( int *tmp, int size )
{
for ( int i = 0; i < size; i++ )
for ( int j = 0; j < size-i-1; j++)
{
if ( tmp[j] > tmp[j+1])
{
int t = tmp[j];
tmp[j] = tmp[j+1];
tmp[j+1] = t;
}
}
}
匿名用户
2013-10-20
展开全部
假设你的数据时int型的。

int *p = null;
int n;
scanf("%d",&n);
p = malloc(n, sizeof(int)); // 这样分配了N个int型数据的空间,并且p指向空间首地址

排序那个就自己采用一种排序方法吧。操作p可以说是跟操作一个数组一样的
p[0]就是第一个元素。p[n-1]就是数组最后一个元素。。

最后调用free(p)释放掉申请的内存
本回答被网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式