C语言中的一个简单程序编译没问题但出错
函数是要把最大值与a[0]交换,最小与a[9]交换编译没问题但是,运行时一直出错,程序自己结束#include<stdio.h>voidscanf_(inta[10]){...
函数是要把最大值与a[0]交换,最小与a[9]交换
编译没问题但是,运行时一直出错,程序自己结束
#include<stdio.h>
void scanf_(int a[10])
{
int i;
for(i=0;i<10;i++)
scanf("%d",&a[i]);
}
void printf_(int a[10])
{
int i;
for(i=0;i<10;i++)
printf("%d",a[i]);
}
void swap_(int *p)
{
int max,min,c,j,k,i;
max=*p;
min=*p;
for(i=0;i<10;i++)
if(*p>*(p+i))
{
j=i;
min=*(p+j);
}
if(*p<*(p+i))
{
k=i;
max=*(p+k);
}
c=*(p+j);
*p=*(p+j);
*(p+j)=c;
c=*(p+k);
*(p+k)=p[9];
p[9]=c;
}
void main()
{
int b[10],*q=NULL,z[10];
scanf_(b);
q=b;
swap_(q);
printf_(b);
}
就是这样的,麻烦看一下 展开
编译没问题但是,运行时一直出错,程序自己结束
#include<stdio.h>
void scanf_(int a[10])
{
int i;
for(i=0;i<10;i++)
scanf("%d",&a[i]);
}
void printf_(int a[10])
{
int i;
for(i=0;i<10;i++)
printf("%d",a[i]);
}
void swap_(int *p)
{
int max,min,c,j,k,i;
max=*p;
min=*p;
for(i=0;i<10;i++)
if(*p>*(p+i))
{
j=i;
min=*(p+j);
}
if(*p<*(p+i))
{
k=i;
max=*(p+k);
}
c=*(p+j);
*p=*(p+j);
*(p+j)=c;
c=*(p+k);
*(p+k)=p[9];
p[9]=c;
}
void main()
{
int b[10],*q=NULL,z[10];
scanf_(b);
q=b;
swap_(q);
printf_(b);
}
就是这样的,麻烦看一下 展开
2个回答
展开全部
调试了一下,修改了几个逻辑错误,增加程序运行完成后暂停。
修改代码和注释如下:
#include<stdio.h>
#include<stdlib.h> //增加支持system("pause")
void scanf_(int a[10])
{
int i;
for(i=0;i<10;i++)
scanf("%d",&a[i]);
}
void printf_(int 激搭胡a[10])
{
int i;
for(i=0;i<10;i++)
printf("%d",a[i]);
}
void swap_(int *p)
{
int max,min,c,j,k,i;
max=*p;
min=*p;
//for(i=0;i<10;i++) //从第二个元素枝漏开始比较
for(i=1;i<10;i++)
{ //用大括号包住循环比较的循环体
//if(*p>*(p+i)) //逻辑错误明拦
if(min>*(p+i))
{
j=i;
min=*(p+j);
}
//if(*p<*(p+i)) //逻辑错误
if(max<*(p+i))
{
k=i;
max=*(p+k);
}
}
//c=*(p+j); //逻辑错误
c=*p;
*p=*(p+j);
*(p+j)=c;
c=*(p+k);
*(p+k)=p[9];
p[9]=c;
}
void main()
{
int b[10],*q=NULL,z[10];
scanf_(b);
q=b;
swap_(q);
printf_(b);
system("pause"); //实现运行结束暂停
}
在VC6调试通过,如下图:
供参考。
2015-12-01
展开全部
#include<stdio.h>
void scanf_(int a[10])
{
int i;
for (i = 0; i < 10; i++)
scanf("%d", &a[i]);
}
void printf_(int a[10])
{
int i;
for (i = 0; i < 10; i++)
printf("%d ", a[i]);
}
void swap_(int *p)
{
int max, min, c, j=0, k=0, i=0;
max = *p;
min = *p;
for (i = 0; i < 10; i++)
{
if (*p > 启友*(p + i))
{
j = i;
min = *(p + j);
}
}
c = *(p + j);
*(p + j) = p[9];
p[9] = c;
for (i = 0; i 握镇< 10; i++)
{
if (*p < *(p + i))
{
k = i;
max = *(p + k);
}
}
c = *(p + k);
*p = 悄皮槐*(p + k);
*(p + k) = c;
}
void main()
{
int b[10], *q = NULL;
scanf_(b);
q = b;
swap_(q);
printf_(b);
}
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询