C++中用动态分配内存来改变数组长度
编写一个程序,输入n个数,然后对这n个数进行排序。输多少个数字由n确定,然后把数字依次放入数组中进行排序,定义了怎么调用也讲下,高手来哦!...
编写一个程序,输入n个数,然后对这n个数进行排序。输多少个数字由n确定,然后把数字依次放入数组中进行排序,定义了怎么调用也讲下,高手来哦!
展开
2个回答
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;
}
}
}
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)释放掉申请的内存
int *p = null;
int n;
scanf("%d",&n);
p = malloc(n, sizeof(int)); // 这样分配了N个int型数据的空间,并且p指向空间首地址
排序那个就自己采用一种排序方法吧。操作p可以说是跟操作一个数组一样的
p[0]就是第一个元素。p[n-1]就是数组最后一个元素。。
最后调用free(p)释放掉申请的内存
本回答被网友采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询