鱼C论坛

 找回密码
 立即注册
查看: 1811|回复: 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
  1. #include  <stdio.h>
  2. #define SIZE 10

  3. int max(int *o, int *p);
  4. int min(int *v, int *p);

  5. void main()
  6. {
  7.         int a[SIZE], i,*p1,*p2;
  8.         int numMax;
  9.         int numMin;
  10.         p1 = &numMax;
  11.         p2 = &numMin;
  12.         for(i=0;i<SIZE;i++)
  13.         {
  14.                 printf("a[%d]=", i);
  15.                 scanf("%d", &a[i]);
  16.         }
  17.         max(a,p1);
  18.         min(a,p2);
  19.         
  20.         printf("max=%d, min=%d\n", numMax, numMin);
  21. }
  22. int max(int *o,int *p)
  23. {
  24.         int max=o[0];
  25.         int i;
  26.         for(i=SIZE-1;i>=0;i--)
  27.         {
  28.                 if(o[i]>max)
  29.                 {
  30.                         max=o[i];
  31.                 }
  32.         }
  33.         *p = max;
  34. }
  35. int min(int *v,int *p)
  36. {
  37.         int min=v[0];
  38.         int i;
  39.         for(i=SIZE-1;i>=0;i--)
  40.         {
  41.                 if(v[i]<min)
  42.                 {
  43.                         min=v[i];
  44.                 }
  45.         }
  46.         *p = min;
  47. }
复制代码
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

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

  3. int max(int *o, int *p);
  4. int min(int *v, int *p);

  5. void main()
  6. {
  7.         int a[SIZE], i,*p1,*p2;
  8.         int numMax;
  9.         int numMin;
  10.         p1 = &numMax;
  11.         p2 = &numMin;
  12.         for(i=0;i<SIZE;i++)
  13.         {
  14.                 printf("a[%d]=", i);
  15.                 scanf("%d", &a[i]);
  16.         }
  17.         max(a,p1);
  18.         min(a,p2);
  19.         
  20.         printf("max=%d, min=%d\n", numMax, numMin);
  21. }
  22. int max(int *o,int *p)
  23. {
  24.         int max=o[0];
  25.         int i;
  26.         for(i=SIZE-1;i>=0;i--)
  27.         {
  28.                 if(o[i]>max)
  29.                 {
  30.                         max=o[i];
  31.                 }
  32.         }
  33.         *p = max;
  34. }
  35. int min(int *v,int *p)
  36. {
  37.         int min=v[0];
  38.         int i;
  39.         for(i=SIZE-1;i>=0;i--)
  40.         {
  41.                 if(v[i]<min)
  42.                 {
  43.                         min=v[i];
  44.                 }
  45.         }
  46.         *p = min;
  47. }
复制代码
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2022-8-11 06:47:25 | 显示全部楼层
本帖最后由 jhq999 于 2022-8-11 06:53 编辑
  1. #include  <stdio.h>
  2. void main()
  3. {
  4.         int max(int *o, int i);
  5.         int min(int *v, int i);
  6.         int a[10], i, *p=a;
  7.         for(i=0;i<=9;i++)
  8.         {
  9.                 printf("a[%d]=", i);
  10.                 scanf("%d", &a[i]);
  11.                 //////////////p=a[i];
  12.         }
  13.         printf("max=%d, min=%d", max(p,i), min(p,i));
  14. }
  15. int max(int *o, int i)
  16. {
  17.         int max=*o;
  18.         for(i=9;i>=0;i--,o--)
  19.         {
  20.                 if(*o>max)
  21.                 {
  22.                         max=*o;
  23.                 }
  24.         }
  25.         return max;
  26. }
  27. int min(int *v, int i)
  28. {
  29.         int min=*v;
  30.         for(i=9;i>=0;i--,v--)
  31.         {
  32.                 if(*v<min)
  33.                 {
  34.                         min=*v;
  35.                 }
  36.         }
  37.         return min;
  38. }
复制代码


  1. void main()
  2. {
  3.         int max=0x80000000;
  4.         int min=0x7fffffff;
  5.         int a[10], i;
  6.         for(i=0;i<=9;i++)
  7.         {
  8.                 printf("a[%d]=", i);
  9.                 scanf("%d", &a[i]);
  10.                 if(max<a[i])
  11.                         max=a[i];
  12.                 else
  13.                         min=a[i];
  14.         }
  15.         printf("max=%d, min=%d", max, min);
  16. }
复制代码
想知道小甲鱼最近在做啥?请访问 -> 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-4-20 18:56

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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