当前位置: 首页 > news >正文

湘潭做网站品牌磐石网络北京seo营销公司

湘潭做网站品牌磐石网络,北京seo营销公司,公司网站管理,用python做美食网站目录 题目 注意: 示例 1: 示例 2: 提示: 题目解析 题目思路 代码思路 数据处理 注意 减法函数 第一次使用的函数 问题 第二次改良后的代码 处理i的值并且返回 总代码 力扣的代码 注意 题目 给你两个整数,被除数 dividend 和…

目录

题目

注意:

示例 1:

示例 2:

提示:

题目解析

题目思路

代码思路

数据处理

注意

减法函数

第一次使用的函数

问题

第二次改良后的代码

处理i的值并且返回

总代码

力扣的代码

注意


题目

给你两个整数,被除数 dividend 和除数 divisor。将两数相除,要求 不使用 乘法、除法和取余运算。

整数除法应该向零截断,也就是截去(truncate)其小数部分。例如,8.345 将被截断为 8 ,-2.7335 将被截断至 -2 。

返回被除数 dividend 除以除数 divisor 得到的  。

注意:

假设我们的环境只能存储 32 位 有符号整数,其数值范围是 [−231,  231 − 1] 。本题中,如果商 严格大于 231 − 1 ,则返回 231 − 1 ;如果商 严格小于 -231 ,则返回 -231 。

示例 1:

输入: dividend = 10, divisor = 3
输出: 3
解释: 10/3 = 3.33333.. ,向零截断后得到 3 。

示例 2:

输入: dividend = 7, divisor = -3
输出: -2
解释: 7/-3 = -2.33333.. ,向零截断后得到 -2 。

提示:

  • -231 <= dividend, divisor <= 231 - 1
  • divisor != 0
    	if (dividend == 0)return 0;if (divisor == 1)return dividend;if (divisor == -1){if (dividend > INT_MIN) return -dividend;// 只要不是最小的那个整数,都是直接返回相反数就好啦return INT_MAX;// 是最小的那个整数,都是直接返回最大值}

题目解析

这是一个让你不用除法来实现除法的题目

很奇怪,代码中不能直接或者间接的用除法,乘法,以及求余

题目思路

由于还可以用减法以及加法

这时候可以想到小学的知识

除法的本质就是看在被除数中有几个除数

我们可以用减法来依次减去就可以了

代码思路

越界的情况

首先我们要判断给出的值越界的情况

	if (dividend == 0)return 0;if (divisor == 1)return dividend;if (divisor == -1){if (dividend > INT_MIN) return -dividend;// 只要不是最小的那个整数,都是直接返回相反数就好啦return INT_MAX;// 是最小的那个整数,都是直接返回最大值}

数据处理

之后我们判断除数与被除数之间的的符号关系并且记录下来

并且为了方便结算全部取绝对值

	long long i = 0;//判断是否异号long long sum_1 = (long long)dividend * divisor;//取绝对值if (dividend < 0)dividend = -dividend;if (divisor < 0)divisor = -divisor;

注意

这里的long long的数据类型是为了防止给出的数据相乘后越界,并且把其中“i”变量的值记录下来用于返回

减法函数

第一次使用的函数

原来是用这个函数的

	while (dividend >= divisor){dividend=dividend-divisor;i++}

问题

运行时间可能会慢因为除数是21亿并且除数是2的话要运行10亿次

第二次改良后的代码

	while (dividend >= divisor){long long j = 1;long long sum_3 = divisor;while (dividend> sum_3 + sum_3){sum_3 = sum_3 + sum_3;j = j + j;}dividend = dividend - sum_3;i = i + j;}

这个实现方法就是

如果是144除以2第一步执行的是144-64第二步为80-64第三步为16-16

这样运行步骤会大大降低

处理i的值并且返回

	if (sum_1 < 0)i = -i;return i;

总代码

可以直接运行的代码

#include <iostream>
using namespace std;
int divide(long long dividend, long long divisor)
{if (dividend == 0)return 0;if (divisor == 1)return dividend;if (divisor == -1){if (dividend > INT_MIN) return -dividend;// 只要不是最小的那个整数,都是直接返回相反数就好啦return INT_MAX;// 是最小的那个整数,都是直接返回最大值}long long i = 0;//判断是否异号long long sum_1 = (long long)dividend * divisor;//取绝对值if (dividend < 0)dividend = -dividend;if (divisor < 0)divisor = -divisor;while (dividend >= divisor){long long j = 1;long long sum_3 = divisor;while (dividend> sum_3 + sum_3){sum_3 = sum_3 + sum_3;j = j + j;}dividend = dividend - sum_3;i = i + j;}if (sum_1 < 0)i = -i;return i;
}
int main()
{//可改传递的数据int a = divide(-2147483648, -3);cout << a << endl;return 0;
}

力扣的代码

力扣提交的代码

class Solution {
public:
int divide(long long dividend, long long divisor)
{if (dividend == 0)return 0;if (divisor == 1)return dividend;if (divisor == -1){if (dividend > INT_MIN) return -dividend;// 只要不是最小的那个整数,都是直接返回相反数就好啦return INT_MAX;// 是最小的那个整数,都是直接返回最大值}long long i = 0;//判断是否异号long long sum_1 = (long long)dividend * divisor;//取绝对值if (dividend < 0)dividend = -dividend;if (divisor < 0)divisor = -divisor;while (dividend >= divisor){long long j = 1;long long sum_3 = divisor;while (dividend> sum_3 + sum_3){sum_3 = sum_3 + sum_3;j = j + j;}dividend = dividend - sum_3;i = i + j;}if (sum_1 < 0)i = -i;return i;
}
};

注意

代码不难,注意越界的数据越界的问题

http://www.dt0577.cn/news/2118.html

相关文章:

  • 武汉做医院网站公司上海企业网站推广
  • 百度网盘网站开发文档模板优化关键词的方法
  • 免费建网站那个好技术教程优化搜索引擎整站
  • 如何申请做网站b2b免费外链发布
  • 德国室内设计网站简述网络营销的特点
  • 廊坊网站快速排名优化百度一下百度一下
  • 网站建设 台州职业技能培训有哪些
  • 如何利用网站新闻做推广东莞整站优化排名
  • 泵阀网站建设旺道seo推广
  • 广东深圳网站建设微信商城开发软文写作300字
  • 免费网站空间php产品推广文案100字
  • 建个好网站搜索引擎优化好做吗
  • 湘潭今天刚刚发生的新闻班级优化大师的优点
  • 网站主机空间价格外包网络推广公司
  • 深圳住 建设局网站关键词推广技巧
  • 购物网站流量怎么做seo页面内容优化
  • 学做烤制食品的网站广州网站定制多少钱
  • 青岛东八区创意做网站优化大师平台
  • 打开一个网站搜索页面跳转js贵阳做网络推广的公司
  • 北京网络营销推广公司seo工程师
  • 北京网站建设服务北京疫情最新消息情况
  • 网站成品免费下载微信公众号小程序怎么做
  • 网站检索 标签关键词规划师
  • 绍兴做网站哪家好百度提交入口地址在哪
  • 有料网b2b官方网站网络优化工具
  • 企业常用系统软件网站关键词优化
  • 可以做视频推广的网站吗登封网站关键词优化软件
  • 做论坛网站的元素手机制作网站的软件
  • 网站怎么在百度做推广方案在线网页制作
  • 个人可以做几个网站最新地址