鱼C论坛

 找回密码
 立即注册
查看: 1242|回复: 6

[已解决]为什么无法得到想得到的结果????

[复制链接]
发表于 2020-3-10 21:24:30 | 显示全部楼层 |阅读模式

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

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

x
#include<stdio.h>
int i, j;
void max( )
{
        int max,a[10];
        for (i = 0; i < 10;i++)
        {
                for (j = 10; j>0; j--)
                {
                        if (a[i] < a[j])
                                max = a[j];
                        else
                                max = a[i];
                }printf("数组中最大的数为%d", max);
        }
}
void min()
{       
        int min, a[10];
        for (i = 0; i < 10; i++)
        {
                for (j = 10; j>0; j--)
                {
                        if (a[i] < a[j])
                                min = a[i];
                        else
                                min= a[j];

                }printf("数组中最小的数为%d", min);
        }
}
main()
{
       
        int a[10];
        for (i = 0; i < 10; i++)
        {
                scanf_s("%d", a[i]);
                printf("%d", a[i]);
        }
        max(a[10]);
        min(a[10]);

}
最佳答案
2020-3-10 21:39:06
本帖最后由 jackz007 于 2020-3-10 21:41 编辑
  1. #include <stdio.h>

  2. int min(int a[] , int n)
  3. {
  4.         int i , m                                                  ;
  5.         for(m = a[0] , i = 1 ; i < n ; i ++) if(a[i] < m) m = a[i] ;
  6.         return m                                                   ;
  7. }        

  8. int max(int a[] , int n)
  9. {
  10.         int i , m                                                  ;
  11.         for(m = a[0] , i = 1 ; i < n ; i ++) if(a[i] > m) m = a[i] ;
  12.         return m                                                   ;
  13. }

  14. int main(void)
  15. {
  16.         int a[10] , i                                   ;
  17.         for(i = 0 ; i < 10 ; i ++) scanf("%d" , & a[i]) ;
  18.         printf("数组中最小的数为:%d\n" , min(a , 10))   ;
  19.         printf("数组中最大的数为:%d\n" , max(a , 10))   ;
  20. }
复制代码

        编译、运行实况:
  1. C:\Bin>g++ -o x x.c

  2. C:\Bin>x
  3. 99
  4. 21
  5. 33
  6. 55
  7. 12
  8. 5
  9. 78
  10. 32
  11. 30
  12. 10
  13. 数组中最小的数为:5
  14. 数组中最大的数为:99

  15. C:\Bin>
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2020-3-10 21:29:19 | 显示全部楼层
本帖最后由 Cool_Breeze 于 2020-3-10 21:31 编辑

把数组a移到申明i,j的后面(作用域你还没有学吧!)
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-3-10 21:34:46 | 显示全部楼层
首先,你是要对数组进行排序对吧?
那为什么在定义的时候没有传入参数呢?
其次,你的调用方式是
  1. max(a[10])
复制代码

这样的话,只会对a的10号元素进行操作
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-3-10 21:34:47 | 显示全部楼层
Cool_Breeze 发表于 2020-3-10 21:29
把数组a移到申明i,j的后面(作用域你还没有学吧!)

没用
我这个是想用冒泡法,找出数组中的最大值与最小值

但是实际的操作结果是只能输入数组的数据就结束了
根本达不到预想的结果
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-3-10 21:37:25 | 显示全部楼层
qiuyouzhi 发表于 2020-3-10 21:34
首先,你是要对数组进行排序对吧?
那为什么在定义的时候没有传入参数呢?
其次,你的调用方式是

该怎么进行调整呢???
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-3-10 21:39:06 | 显示全部楼层    本楼为最佳答案   
本帖最后由 jackz007 于 2020-3-10 21:41 编辑
  1. #include <stdio.h>

  2. int min(int a[] , int n)
  3. {
  4.         int i , m                                                  ;
  5.         for(m = a[0] , i = 1 ; i < n ; i ++) if(a[i] < m) m = a[i] ;
  6.         return m                                                   ;
  7. }        

  8. int max(int a[] , int n)
  9. {
  10.         int i , m                                                  ;
  11.         for(m = a[0] , i = 1 ; i < n ; i ++) if(a[i] > m) m = a[i] ;
  12.         return m                                                   ;
  13. }

  14. int main(void)
  15. {
  16.         int a[10] , i                                   ;
  17.         for(i = 0 ; i < 10 ; i ++) scanf("%d" , & a[i]) ;
  18.         printf("数组中最小的数为:%d\n" , min(a , 10))   ;
  19.         printf("数组中最大的数为:%d\n" , max(a , 10))   ;
  20. }
复制代码

        编译、运行实况:
  1. C:\Bin>g++ -o x x.c

  2. C:\Bin>x
  3. 99
  4. 21
  5. 33
  6. 55
  7. 12
  8. 5
  9. 78
  10. 32
  11. 30
  12. 10
  13. 数组中最小的数为:5
  14. 数组中最大的数为:99

  15. C:\Bin>
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-3-10 21:41:28 | 显示全部楼层
WFR 发表于 2020-3-10 21:37
该怎么进行调整呢???
  1. #include<stdio.h>

  2. int i, j, a[12];
  3. int max1(int a[]);
  4. int min1(int a[]);
  5. int max1(int a[])
  6. {
  7.          int max;
  8.          for (i = 0; i < 10;i++)
  9.          {
  10.                  for (j = 10; j>0; j--)
  11.                  {
  12.                          if (a[i] < a[j])
  13.                                  max = a[j];
  14.                          else
  15.                                  max = a[i];
  16.                  }
  17.          }
  18.                  return max;
  19. }
  20. int min1(int a[])
  21. {        
  22.          int min;
  23.          for (i = 0; i < 10; i++)
  24.          {
  25.                  for (j = 10; j > 0; j--)
  26.                  {
  27.                          if (a[i] < a[j])
  28.                                  min = a[i];
  29.                          else if (a[i] > a[j])
  30.                                  min = a[j];
  31.                  }
  32.          }
  33.          return min;
  34. }
  35. int main()
  36. {
  37.          
  38.         for (i = 0; i < 10; i++)
  39.         {
  40.                 scanf("%d", &a[i]);
  41.                 //printf("%d\n", a[i]);
  42.         }
  43.         int amax = max1(a);
  44.         int amin = min1(a);
  45.         printf("最大值:%d 最小值:%d", amax, amin-1);
  46.         return 0;

  47. }
复制代码

先写一个
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-7-6 11:38

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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