如题,小弟最近刚学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