鱼C论坛

 找回密码
 立即注册
查看: 993|回复: 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 编辑
#include <stdio.h>

int min(int a[] , int n)
{
        int i , m                                                  ;
        for(m = a[0] , i = 1 ; i < n ; i ++) if(a[i] < m) m = a[i] ;
        return m                                                   ;
}        

int max(int a[] , int n)
{
        int i , m                                                  ;
        for(m = a[0] , i = 1 ; i < n ; i ++) if(a[i] > m) m = a[i] ;
        return m                                                   ;
}

int main(void)
{
        int a[10] , i                                   ;
        for(i = 0 ; i < 10 ; i ++) scanf("%d" , & a[i]) ;
        printf("数组中最小的数为:%d\n" , min(a , 10))   ;
        printf("数组中最大的数为:%d\n" , max(a , 10))   ;
}
        编译、运行实况:
C:\Bin>g++ -o x x.c

C:\Bin>x
99
21
33
55
12
5
78
32
30
10
数组中最小的数为:5
数组中最大的数为:99

C:\Bin>
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

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

把数组a移到申明i,j的后面(作用域你还没有学吧!)
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-3-10 21:34:46 | 显示全部楼层
首先,你是要对数组进行排序对吧?
那为什么在定义的时候没有传入参数呢?
其次,你的调用方式是
max(a[10])
这样的话,只会对a的10号元素进行操作
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

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

但是实际的操作结果是只能输入数组的数据就结束了
根本达不到预想的结果
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

该怎么进行调整呢???
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

int min(int a[] , int n)
{
        int i , m                                                  ;
        for(m = a[0] , i = 1 ; i < n ; i ++) if(a[i] < m) m = a[i] ;
        return m                                                   ;
}        

int max(int a[] , int n)
{
        int i , m                                                  ;
        for(m = a[0] , i = 1 ; i < n ; i ++) if(a[i] > m) m = a[i] ;
        return m                                                   ;
}

int main(void)
{
        int a[10] , i                                   ;
        for(i = 0 ; i < 10 ; i ++) scanf("%d" , & a[i]) ;
        printf("数组中最小的数为:%d\n" , min(a , 10))   ;
        printf("数组中最大的数为:%d\n" , max(a , 10))   ;
}
        编译、运行实况:
C:\Bin>g++ -o x x.c

C:\Bin>x
99
21
33
55
12
5
78
32
30
10
数组中最小的数为:5
数组中最大的数为:99

C:\Bin>
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

int i, j, a[12];
int max1(int a[]);
int min1(int a[]);
int max1(int a[])
 {
         int max;
         for (i = 0; i < 10;i++)
         {
                 for (j = 10; j>0; j--)
                 {
                         if (a[i] < a[j])
                                 max = a[j];
                         else
                                 max = a[i];
                 }
         }
                 return max;
 }
 int min1(int a[])
 {        
         int min;
         for (i = 0; i < 10; i++)
         {
                 for (j = 10; j > 0; j--)
                 {
                         if (a[i] < a[j])
                                 min = a[i];
                         else if (a[i] > a[j])
                                 min = a[j];
                 }
         }
         return min;
 }
int main()
 {
         
        for (i = 0; i < 10; i++)
        {
                scanf("%d", &a[i]);
                //printf("%d\n", a[i]);
        }
        int amax = max1(a);
        int amin = min1(a);
        printf("最大值:%d 最小值:%d", amax, amin-1);
        return 0;

}
先写一个
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-1-15 20:55

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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