[讨论] 用指标排序?

楼主: freddy (30cmer)   2020-05-09 11:27:08
如题,小弟最近刚学c++(学到指标阵列这边),刚刚在用指标排序数字时,有点问题
题目如下:
有多笔测资以EOF为结束
第一行有一个正整数n(1<=n<=1000),代表有几个数字要排
第二行有n个可以用int储存的正整数
例如:
6
7 9 0 4 1 8
8
1 9 9 0 0 9 2 8
我的码:
#include <iostream>
#include <cstdlib>
using namespace std;
int *ptr,i,p,index;
void fc(int);
int main(void)
{
while(scanf("%d",&i)!=EOF){
ptr=(int*)malloc(i*4);
fc(i);
free(ptr);
}
return 0;
}
void fc(int p){
int j,k,stay;
for(index=0;index<p;index++,ptr++){
cin>>*ptr;
}
ptr-=p;
for(j=0;j<p;j++){
for(k=0;k<(p-1);k++){
if(*(ptr+k)>*(ptr+k+1)){
stay=*(ptr+k);
*(ptr+k)=*(ptr+k+1);
*(ptr+k+1)=stay;
}
}
p
作者: Lipraxde (Lipraxde)   2020-05-09 14:06:00
你在输出看到的是你用 cout 输出的结果,并不是 main回传的值。fc 最后在输出排序结果后没有把 ptr 扣回去,所以在 free 的时候出问题,导致程式没继续跑。你可以先从“想清楚 fc 要做啥、需要哪些参数?”开始改善这只程式

Links booklink

Contact Us: admin [ a t ] ucptt.com