新网创想网站建设,新征程启航
为企业提供网站建设、域名注册、服务器等服务
#includestdio.h
创新互联公司成立与2013年,先为东辽等服务建站,东辽等地企业,进行企业商务咨询服务。为东辽企业网站制作PC+手机+微官网三网同步一站式服务解决您的所有建站问题。
int main()
{
int a[5];
int i,max,min;
printf("input number:\n");
for(i=0;i5;i++)
scanf("%d",a[i]);
max=a[0];
min=a[0];
for(i=0;i5;i++){
if(a[i]max)
max=a[i];
}
for(i=0;i5;i++){
if(a[i]min)
min=a[i];
}
for(i=0;i5;i++){
printf("%d",a[i]);
printf(" ");
}
printf("\n");
printf("最大值为%d\n",max);
printf("最小值为%d\n",min);
return 0;
}
首先,指针默认只有一个地址的长度的空间,存不了那么多的字符。
其次,传值和传地址一塌糊涂,完全就是乱写么。
scanf的第二个参数是地址,如果本身不是指针则需要取址符。
我给你重写了算了
#includestdio.h
int Retrieve(int array[],int length,int x);/*形参x直接传值就可以了*/
int main()
{
int *a,x;
int length,i;
scanf("%d",length);
a = (int)malloc(sizeof(int)*length); /*申请一个内存空间用来存放数据,或者直接用一个大数组也可以*/
#include stdio.h
#define N 5 /*数组的大小*/
void input(int *a,int n)/*输入函数*/
{
int *p=a;
while(pa+n)
scanf("%d",p++);
}
void output(int *a,int n)/*输出函数*/
{
int *p=a;
while(pa+n)
printf("%d ",*p++);
printf("\n");
}
void isort(int *s,int n)/*排序函数*/
{
int i,j;
int *p,temp;
for(i=0;in-1;i++)
{
p=s+i;
for(j=i;jn;j++)
if(*ps[j])
p=s+j;
temp=*p;
*p=s[i];
s[i]=temp;
}
}
int binsh(int *a, int c, int low, int high)/*递归法实现的二分查找法,元素存在于a中则返回元素的第一个位置,不存在则返回-1*/
{
int mid=(high+low)/2;
if(lowhigh)
return -1;
if(ca[mid])
return binsh(a,c,mid+1,high);
else if(ca[mid])
return binsh(a,c,low,mid-1);
else
return mid;
}
int main()
{
int a[N],n;
input(a,N);/*输入*/
isort(a,N);/*排序*/
output(a,N);/*输出*/
scanf("%d",n);/*要查找的元素*/
printf("%d\n",binsh(a,n,0,N-1));/*存在的话打印位置,不存在的话打印-1*/
return 0;
}
有用的话,请楼主及时采纳,谢谢