码迷,mamicode.com
首页 > 编程语言 > 详细

随机产生20个[10 , 50]的正整数存到数组中,并求数组中的所有元素最大值、最小值、平均值以及各元素之和,及第二大值。

时间:2014-12-18 20:43:57      阅读:545      评论:0      收藏:0      [点我收藏+]

标签:random   c语言   编程   secondmax   冒泡排序   

int a[20] = {0};//定义一个长度为20的数组a
    int max = 0;//用来存储数组a中所有元素的最大值
    int min = 0;//用来存储数组a中所有元素的最小值
    int sum = 0;//用来存储数组a各元素的和
    float aver = 0.0;//用来存储数组a中所有元素的平均值
    int secondMax = 0;//用来存储数组a的第二大值,第二大值 为 不同于最大值的剩余元素的最大值
    for (int i = 0; i < 20; i++) {//用来循环获取20个随机值,并把它们放到数组a中相应的位置,并把获取到的数打印出来
        a[i] = arc4random() % (50 - 10 + 1) + 10;
        sum += a[i];//计算数组a中元素的值
        printf("%d ", a[i]);
    }
    aver = (float)sum / 20;
    printf("sum = %d aver = %f\n", sum, aver);
    
    for (int i = 0; i < 20; i++) {
        if (i == 0) {//把a[0]的值赋值给max 和 secondMax, min,主要是为了防止获取到的20个数都比max 和 secondMax最初定义时赋的值小, 或者都比min大,从而影响正确的结果,在此处max 和 secondMax 没有这种情况,因为随机值的范围是10~50,这里写出只是为了标示出可能会出现这种情况,同时,防止min出现这种情况
            max = a[i];
            secondMax = a[i];
            min = a[0];
        } else {
            if (max < a[i]) {
                secondMax = max;
                max = a[i];
            } else if (secondMax < a[i] && a[i] != max) {
                secondMax = a[i];
            }
            
            if (min > a[i]) {
                min = a[i];
            }
        }
    }
    printf("max = %d min = %d secondMax = %d", max, min, secondMax);

随机产生20个[10 , 50]的正整数存到数组中,并求数组中的所有元素最大值、最小值、平均值以及各元素之和,及第二大值。

标签:random   c语言   编程   secondmax   冒泡排序   

原文地址:http://blog.csdn.net/andyknow/article/details/42009779

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!