[华为机试练习题]53.整数相除(AC 但还有bug)

简介:

题目

描述:
实现接口:

/---------------------------------------------------------------------------------
 Description  : 整数相除。
 Input        : unsigned int dividend :被除数,取值为无符号整数。
                unsigned int divisor: 除数,取值为无符号整数。
 Output       : Char *pResult       : 运算结果。
 Return Value : 0:成功; -1:失败;
---------------------------------------------------------------------------------/
int IntegerDivision (unsigned int dividend,  
                           unsigned int divisor,
                           Char *pResult); 
说明:
Char *pResult的空间由调用者提供,结果中最多保存十位整数,五位小数,整数部分超出十位,返回失败;小数部分超出五位,四舍五入;
存储结果以字符串形式显示,整数和小数部分需加上小数点。如结果为2.05,则输出的结果为”2.05”。

练习阶段:

中级 

代码

/*---------------------------------------
*   日期:2015-07-04
*   作者:SJF0115
*   题目:整数相除 
*   来源:华为机试练习题
-----------------------------------------*/
#include <iostream>
#include "oj.h"
#include <vector>
using namespace std;

// 提取各位上数
vector<int> NumSplit(int num){
    vector<int> result;
    if(num == 0){
        result.push_back(0);
        return result;
    }//if
    while(num){
        result.insert(result.begin(),num % 10);
        num /= 10;
    }//while
    return result;
}
/***********************************************************************
 Description  : 整数相除。
 Input        : unsigned int dividend :被除数,取值为无符号整数。
                unsigned int divisor: 除数,取值为无符号整数。
 Output       : Char *pResult       : 运算结果。
 Return Value : 0:成功; -1:失败;
***********************************************************************/
int IntegerDivision (unsigned int dividend, unsigned int divisor,char *pResult){
    if(pResult == NULL){
        return -1;
    }//if
    // 除数不能为0
    if(divisor == 0){
        return -1;
    }//if
    // 整数部分
    int result = dividend / divisor;
    vector<int> integerVec = NumSplit(result);
    // 整数部分超出十位,返回失败
    int intergerSize = integerVec.size();
    if(intergerSize > 10){
        return -1;
    }//if
    int index = 0;
    for(int i = 0;i < intergerSize;++i){
        pResult[index++] =  integerVec[i] + '0';
    }//for

    // 小数部分 乘以1000000 截取小数前6位
    int result2 = dividend % divisor * 1000000 / divisor;
    // 无小数
    if(result2 == 0){
        pResult[index] = '\0';
        return 0;
    }//if
    vector<int> pointVec = NumSplit(result2);
    int pointSize = pointVec.size();
    // 四舍五入
    if(pointSize > 5){
        if(pointVec[5] >= 5){
            ++pointVec[4];
        }//if
        // 去掉小数第6位 只保留5位
        pointVec.pop_back();
        --pointSize;
    }//if

    pResult[index++] = '.';
    for(int i = 0;i < pointSize;++i){
        pResult[index++] =  pointVec[i] + '0';
    }//for

    // 删除后导0  9/8 = 1.12500
    for(int i = index-1;i >= 0;--i){
        if(pResult[i] != '0'){
            index = i+1;
            break;
        }//if
    }//for
    pResult[index] = '\0';
    //cout<<"整数->"<<result<<"    小数->"<<result2<<endl;
    return 0;
}
目录
相关文章
|
7月前
|
C语言
【C语言刷题每日一题#牛客网BC6】输入三个整数,输出第二个整数
【C语言刷题每日一题#牛客网BC6】输入三个整数,输出第二个整数
|
7月前
|
C语言
C语言——oj刷题——调整数组使奇数全部都位于偶数前面
C语言——oj刷题——调整数组使奇数全部都位于偶数前面
46 1
|
8月前
|
C语言
pta浙大版《C语言程序设计(第3版)》 习题6-4 使用函数输出指定范围内的Fibonacci数 (20分)
pta浙大版《C语言程序设计(第3版)》 习题6-4 使用函数输出指定范围内的Fibonacci数 (20分)
|
8月前
|
C语言
pta 浙大版《C语言程序设计(第3版)》题目集 习题6-6 使用函数输出一个整数的逆序数 (20分)
pta 浙大版《C语言程序设计(第3版)》题目集 习题6-6 使用函数输出一个整数的逆序数 (20分)
|
容器
华为机试HJ60:查找组成一个偶数最接近的两个素数
华为机试HJ60:查找组成一个偶数最接近的两个素数
华为机试每日一练--第十二题: 查找组成一个偶数最接近的两个素数
华为机试每日一练--第十二题: 查找组成一个偶数最接近的两个素数
华为机试每日一练--第十二题: 查找组成一个偶数最接近的两个素数
|
人工智能 C语言
C语言求100以内的偶数和、求十个数的乘积习题示例
C语言求100以内的偶数和、求十个数的乘积习题示例
434 0
C语言求100以内的偶数和、求十个数的乘积习题示例
|
算法 前端开发 程序员
「LeetCode」剑指Offer-16数值的整数次方⚡️
「LeetCode」剑指Offer-16数值的整数次方⚡️
105 0
「LeetCode」剑指Offer-16数值的整数次方⚡️
|
C语言
浙大版《C语言程序设计(第3版)》题目集 - 习题6-4 使用函数输出指定范围内的Fibonacci数(20 分)
浙大版《C语言程序设计(第3版)》题目集 - 习题6-4 使用函数输出指定范围内的Fibonacci数(20 分)
125 0