[华为机试练习题]16.数字统计

题目

题目标题:

对输入的整型数组,输出数组元素中的最大值、最大值的个数、最小值和最小值的个数
详细描述:

接口说明
原型:
voidOutputMaxAndMin(int * pInputInteger,intInputNum,int * pMaxValue,int * pMaxNum,int * pMinValue,int * pMinNum);
输入参数:
    Int * pInputInteger:整型数组指针
Int   InputNum:数组元素个数
输出参数(指针指向的内存区域保证有效):
    int* pMaxValue:数组中最大值
     int* pMaxNum:数组中最大值的个数
     int* pMinValue:数组中最小值
int* pMinNum:数组中最小值的个数
返回值:
    void
涉及知识点:

C语言基础:数组、比较
性能要求:

无
圈复杂度要求:

这个不由出题者提供,由后续判题系统全局配置
如:函数圈复杂度低于10,类公函数小于20等
代码工程和用例:
C/C++:
VS2005代码工程
嵌入工程的CPPUNIT用例

知识点:
工程环境请使用VS2005

题目来源:    软件训练营
维护人:     d00191780
练习阶段:    初级

代码

/*---------------------------------------
*   日期:2015-06-30
*   作者:SJF0115
*   题目:数字统计
*   来源:华为上机
-----------------------------------------*/
#include <stdio.h>

/*
功能:对输入的整型数组,输出数组元素中的最大值、最大值的个数、最小值和最小值的个数

输入:int * pInputInteger:整型数组指针
     int * InputNum:数组元素个数

输出:int * pMaxValue:数组中最大值
     int * pMaxNum:数组中最大值的个数
     int * pMinValue:数组中最小值
     int * pMinNum:数组中最小值的个数

返回:void
*/
void OutputMaxAndMin(int * pInputInteger, int InputNum, int * pMaxValue, int * pMaxNum, int * pMinValue, int * pMinNum)
{
    if(pInputInteger == NULL || InputNum <= 0){
        return;
    }//if
    *pMaxValue = pInputInteger[0];
    *pMinValue = pInputInteger[0];
    *pMaxNum = 1;
    *pMinNum = 1;
    for(int i = 1;i < InputNum;++i){
        // 更新最大值
        if(pInputInteger[i] > *pMaxValue){
            *pMaxValue = pInputInteger[i];
            *pMaxNum = 1;
        }//if
        else if(pInputInteger[i] == *pMaxValue){
            ++(*pMaxNum);
        }//else
        // 更新最小值
        if(pInputInteger[i] < *pMinValue){
            *pMinValue = pInputInteger[i];
            *pMinNum = 1;
        }//if
        else if(pInputInteger[i] == *pMinValue){
            ++(*pMinNum);
        }//else
    }//for
    return;
}

版权声明:本文为博主原创文章,未经博主允许不得转载。

时间: 2024-07-28 15:47:12

[华为机试练习题]16.数字统计的相关文章

[华为机试练习题]43.在字符串中找出连续最长的数字串

题目 描述: 请一个在字符串中找出连续最长的数字串,并把这个串的长度返回:如果存在长度相同的连续数字串,返回最后一个连续数字串: 注意:数字串只需要是数字组成的就可以,并不要求顺序,比如数字串"1234"的长度就小于数字串"1359055",如果没有数字,则返回空字符串("")而不是NULL! 样例输入 abcd12345ed125ss123058789 abcd12345ss54761 样例输出 输出123058789,函数返回值9 输出547

[华为机试练习题]34.识别有效的IP地址和掩码并进行分类统计

题目 描述: 请解析IP地址和对应的掩码,进行分类识别.要求按照A/B/C/D/E类地址归类,不合法的地址和掩码单独归类. 所有的IP地址划分为 A,B,C,D,E五类 A类地址1.0.0.0~126.255.255.255; B类地址128.0.0.0~191.255.255.255; C类地址192.0.0.0~223.255.255.255; D类地址224.0.0.0~239.255.255.255: E类地址240.0.0.0~255.255.255.255 私网IP范围是: 10.0

[华为机试练习题]25.圆桌游戏

题目 描述: 详细描述: N个人围坐在一个圆桌上,顺时针报数,报数的初始值为第一个人设置.当有成员报出的数字为7的倍数或数字中包含7,则该人退出圆桌,而后由下一个人开始重新继续该游戏. 实现以下接口: 1.设定输入原始的圆桌游戏的人数.以最先开始报数的人编号为1,顺时针排序. 2.设定第一个人的初始值,获取按照规则退出圆桌的人的编号. 3.结束游戏. 样例: 比如初始化为4人的游戏:第1轮初始值为1,退出为3:第2轮初始值为4,退出为4号:第三轮初始值为16,退出为2号:第四轮初始值为6,退出为

[华为机试练习题]36.简单错误记录(错误 求正解)

题目 描述: 开发一个简单错误记录功能小模块,能够记录出错的代码所在的文件名称和行号. 处理: 1. 记录最多8条错误记录,循环记录,对相同的错误记录(净文件名称和行号完全匹配)只记录一条,错误计数增加: 2. 超过16个字符的文件名称,只记录文件的最后有效16个字符: 3. 输入的文件可能带路径,记录文件名称不能带路径. 题目类别: 字符串 难度: 中级 运行时间限制: 10Sec 内存限制: 128MByte 阶段: 入职前练习 输入: 一行或多行字符串.每行包括带路径文件名称,行号,以空格

[华为机试练习题]44.24点游戏算法

题目 注意: 6 + 2 * 4 + 10 = 24 不是一个数字一个数字的计算 代码 /*--------------------------------------- * 日期:2015-07-03 * 作者:SJF0115 * 题目:24点游戏算法 * 来源:华为机试练习题 -----------------------------------------*/ #include <iostream> #include <string> #include <vector&

[华为机试练习题]46.计算二进制数的0的个数

题目 描述: 输入一个10进制数字,请计算该数字对应二进制中0的个数,注意左数第一个1之前的所有0都不需要计算.不需要考虑负数的情况. 题目类别: 位运算 难度: 初级 运行时间限制: 无限制 内存限制: 无限制 阶段: 入职前练习 输入: 要计算的十进制非负数 输出: 二进制中第一个1之后0 的个数 样例输入: 2 样例输出: 1 代码 /*--------------------------------------- * 日期:2015-07-03 * 作者:SJF0115 * 题目:计算二

[华为机试练习题]24.删除链表中的反复节点、剩余节点逆序输出

题目 描写叙述: 题目描写叙述: 输入一个不带头节点的单向链表(链表的节点数小于100),删除链表中内容反复的节点(反复的节点所有删除),剩余的节点逆序倒排. 要求实现函数: void vChanProcess(strNode * pstrIn,strNode * pstrOut); [输入] pstrIn:输入一个不带头节点的单向链表 [输出] pstrOut:删除内容反复的节点(反复的节点所有删除).剩余节点逆序输出(不带头节点,链表第一个节点的内存已经申请). [注意]仅仅须要完毕该函数功

[华为机试练习题]48.阿姆斯特朗数

题目 描述: 如果一个正整数等于其各个数字的立方和,则该数称为阿姆斯特朗数(亦称为自恋性数),1除外,如407 = 43+03+73就是一个阿姆斯特朗数.试编程求n(n ≤ 65536)以内的所有阿姆斯特朗数. 接口说明 原型: int CalcArmstrongNumber(int n); 输入参数: int n: n ≤ 65536 返回值: n以内的阿姆斯特朗数的数量 练习阶段: 初级 代码 /*--------------------------------------- * 日期:20

[华为机试练习题]24.删除链表中的重复节点、剩余节点逆序输出

题目 描述: 题目描述: 输入一个不带头节点的单向链表(链表的节点数小于100),删除链表中内容重复的节点(重复的节点全部删除),剩余的节点逆序倒排. 要求实现函数: void vChanProcess(strNode * pstrIn,strNode * pstrOut); [输入] pstrIn:输入一个不带头节点的单向链表 [输出] pstrOut:删除内容重复的节点(重复的节点全部删除),剩余节点逆序输出(不带头节点,链表第一个节点的内存已经申请). [注意]只需要完成该函数功能算法,中