鱼C论坛

 找回密码
 立即注册
查看: 2256|回复: 5

[已解决]写关于指针的课后题时程序有问题

[复制链接]
发表于 2022-8-10 22:50:09 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
题目是从十个数字中找出最大值和最小值。
程序如下,小白实在不晓得哪儿出问题了,还望各位能帮忙看一下
#include  <stdio.h>
void main()
{
        int max(int *o, int i);
        int min(int *v, int i);
        int a[10], i, *p;
        for(i=0;i<=9;i++)
        {
                printf("a[%d]=", i);
                scanf("%d", &a[i]);
                p=a[i];
        }
        printf("max=%d, min=%d", max(*p,i), min(*p,i));
}
int max(int *o, int i)
{
        int max=o;
        for(i=9;i>=0;i--,*o--)
        {
                if(o>max)
                {
                        max=o;
                }
        }
}
int min(int *v, int i)
{
        int min=v;
        for(i=9;i>=0;i--,*v--)
        {
                if(v<min)
                {
                        min=v;
                }
        }
}
最佳答案
2022-8-10 23:18:56
#include  <stdio.h>
#define SIZE 10

int max(int *o, int *p);
int min(int *v, int *p);

void main()
{
        int a[SIZE], i,*p1,*p2;
        int numMax;
        int numMin;
        p1 = &numMax;
        p2 = &numMin;
        for(i=0;i<SIZE;i++)
        {
                printf("a[%d]=", i);
                scanf("%d", &a[i]);
        }
        max(a,p1);
        min(a,p2);
        
        printf("max=%d, min=%d\n", numMax, numMin);
}
int max(int *o,int *p)
{
        int max=o[0];
        int i;
        for(i=SIZE-1;i>=0;i--)
        {
                if(o[i]>max)
                {
                        max=o[i];
                }
        }
        *p = max;
}
int min(int *v,int *p)
{
        int min=v[0];
        int i;
        for(i=SIZE-1;i>=0;i--)
        {
                if(v[i]<min)
                {
                        min=v[i];
                }
        }
        *p = min;
}
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2022-8-10 23:18:56 | 显示全部楼层    本楼为最佳答案   
#include  <stdio.h>
#define SIZE 10

int max(int *o, int *p);
int min(int *v, int *p);

void main()
{
        int a[SIZE], i,*p1,*p2;
        int numMax;
        int numMin;
        p1 = &numMax;
        p2 = &numMin;
        for(i=0;i<SIZE;i++)
        {
                printf("a[%d]=", i);
                scanf("%d", &a[i]);
        }
        max(a,p1);
        min(a,p2);
        
        printf("max=%d, min=%d\n", numMax, numMin);
}
int max(int *o,int *p)
{
        int max=o[0];
        int i;
        for(i=SIZE-1;i>=0;i--)
        {
                if(o[i]>max)
                {
                        max=o[i];
                }
        }
        *p = max;
}
int min(int *v,int *p)
{
        int min=v[0];
        int i;
        for(i=SIZE-1;i>=0;i--)
        {
                if(v[i]<min)
                {
                        min=v[i];
                }
        }
        *p = min;
}
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2022-8-11 06:47:25 | 显示全部楼层
本帖最后由 jhq999 于 2022-8-11 06:53 编辑
#include  <stdio.h>
void main()
{
        int max(int *o, int i);
        int min(int *v, int i);
        int a[10], i, *p=a;
        for(i=0;i<=9;i++)
        {
                printf("a[%d]=", i);
                scanf("%d", &a[i]);
                //////////////p=a[i];
        }
        printf("max=%d, min=%d", max(p,i), min(p,i));
}
int max(int *o, int i)
{
        int max=*o;
        for(i=9;i>=0;i--,o--)
        {
                if(*o>max)
                {
                        max=*o;
                }
        }
        return max;
}
int min(int *v, int i)
{
        int min=*v;
        for(i=9;i>=0;i--,v--)
        {
                if(*v<min)
                {
                        min=*v;
                }
        }
        return min;
}

void main()
{
        int max=0x80000000;
        int min=0x7fffffff;
        int a[10], i;
        for(i=0;i<=9;i++)
        {
                printf("a[%d]=", i);
                scanf("%d", &a[i]);
                if(max<a[i])
                        max=a[i];
                else
                        min=a[i];
        }
        printf("max=%d, min=%d", max, min);
}
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2022-8-11 08:39:22 | 显示全部楼层
void main()
{
        int max=0x80000000;
        int min=0x7fffffff;
        int a[10], i;
        for(i=0;i<=9;i++)
        {
                printf("a[%d]=", i);
                scanf("%d", &a[i]);
                if(max<a[i])
                        max=a[i];
                else
                        min=a[i];
        }
        printf("max=%d, min=%d", max, min);
}
最大值和最小值反了
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2022-8-11 08:40:11 | 显示全部楼层

最小值是一个负数,最大值是一个正整数
0X7 fff ff if,是正整书说
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2022-8-11 08:43:24 | 显示全部楼层
aaron0919 发表于 2022-8-11 08:40
最小值是一个负数,最大值是一个正整数
0X7 fff ff if,是正整书说

把最小值初始值赋值成最大的数
最大值初始值赋值成最小的数
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-11-17 01:49

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表