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

在哪个网站找事做靠谱网络推广图片大全

在哪个网站找事做靠谱,网络推广图片大全,芜湖企业网站建设,wordpress占资源我们之前做题碰到的数据范围一般是10^9,多点会达到10^18级别,处理10^9用int就可以存下,10^18次方要用到long long,接着解决加减乘除的问题,但是当数据范围达到了10^10^6的时候,当数据的值特别⼤&#xff0c…
我们之前做题碰到的数据范围一般是10^9,多点会达到10^18级别,处理10^9用int就可以存下,10^18次方要用到long long,接着解决加减乘除的问题,但是当数据范围达到了10^10^6的时候,当数据的值特别⼤,各种类型都存不下的时候,此时就要⽤⾼精度算法来计算加减乘除:
  • 先⽤字符串读⼊这个数,然后⽤数组逆序存储该数的每⼀位;(把123放在我们眼前,我们会认为他是个数字,在计算机视角中看123的时候,是把它们当成1字符,2字符,3字符来看的,我们用字符串string读数的时候,它就会把这个数当成字符串读进来,如果一个数据范围是10^4,撑死这个字符串的长度就是10^4长度的一个字符串而已;我们做计算的时候是先从个位数开始的,比如123+45,先是3+5=8,2+4=6,1+0=1,一共是168,所以逆序的时候,a数组下标为0的位置存的正好是个位,从下标为0,逐渐向后走的时候,是从个位到十位到百位,正好跟我们的计算过程是一一对应的,比如数组从左往右遍历的时候,是在模拟加法计算过程,也就是最低位到最高位,所以我们第一步要先把它逆序存在数组中,这是方便的形式一,有的时候处理到进位的时候,如果正序存的话,进位的那一位就不知道放在哪里了,所以第一步是要把它的每一位逆序的存在数组中)
  • 利⽤数组,模拟加减乘除运算的过程

  •  ⾼精度算法本质上还是模拟算法,⽤代码模拟⼩学列竖式计算加减乘除的过程

题目链接: P1601 A+B Problem(高精) - 洛谷

1.题目

2.算法原理

  1. 先用字符串读入,拆分每一位,逆序放在数组中
  2. 利用数组,模拟小学列竖式计算加法的过程

把123放在我们眼前,我们会认为他是个数字,在计算机视角中看123的时候,是把它们当成1字符,2字符,3字符来看的,我们用字符串string读数的时候,它就会把这个数当成字符串读进来,如果一个数据范围是10^4,撑死这个字符串的长度就是10^4长度的一个字符串而已

我们做计算的时候是先从个位数开始的,比如123+45,先是3+5=8,2+4=6,1+0=1,一共是168,所以逆序的时候,a数组下标为0的位置存的正好是个位,从下标为0,逐渐向后走的时候,是从个位到十位到百位,正好跟我们的计算过程是一一对应的,比如数组从左往右遍历的时候,是在模拟加法计算过程,也就是最低位到最高位,所以我们第一步要先把它逆序存在数组中,这是方便的形式一,有的时候处理到进位的时候,如果正序存的话,进位的那一位就不知道放在哪里了,所以第一步是要把它的每一位逆序的存在数组中

x里面存着“439”字符串,a数组里面存着934,它们的下标是有对应关系的,x里面的4对应的下标,加上a数组里面的4对应的下标之和是2,其他x和a数组里面的两个元素所对应的下标之和分别也是2,可以发现对应位置的下标相加正好是字符串的长度-1,因此一会逆序的时候用一个变量 i 从前往后遍历字符串的时候,在a数组中对应的位置是n-1-i ,因为下标之和相加等于n -1,还有注意在遍历x的时候拿到的是它的字符,如果要拿它里面的数要减去’0’

如果是99+1的话,lc的长度等于2,结果是100,所以实际lc的程度应该等于3,所以我们要处理一下这种情况,如果当前lc里面存着值,我们要让lc的实际长度+1

总结过程(上面是数组模拟例子)
  1. 对应位相加,然后加上进位 -> x
  2. 处理进位 i  -> 13/10=1,进一位
  3. 处理余数 -> 13%10=3

代码

#include <iostream>
using namespace std;const int N = 1e6 + 10;
int a[N], b[N], c[N];
int la, lb, lc; //分别标记abc数组长度// 高精度加法的模版 - c = a + b;
void add(int c[], int a[], int b[])
{for (int i = 0; i < lc; i++){c[i] += a[i] + b[i]; // 对应位相加,再加上进位 9+4=13c[i + 1] += c[i] / 10; // 处理进位 13/10=1c[i] %= 10; // 处理余数 13%10=3}if (c[lc]) lc++;
}int main()
{string x, y; cin >> x >> y;// 1. 拆分每一位,逆序放在数组中la = x.size(); lb = y.size(); lc = max(la, lb);for (int i = 0; i < la; i++) a[la - 1 - i] = x[i] - '0';for (int i = 0; i < lb; i++) b[lb - 1 - i] = y[i] - '0';// 2. 模拟加法的过程add(c, a, b); // c = a + b// 输出结果for (int i = lc - 1; i >= 0; i--) cout << c[i];return 0;
}
http://www.dtcms.com/wzjs/406230.html

相关文章:

  • 12306网站建设团队周口网站制作
  • 网站制作首页微博搜索引擎优化
  • 邢台提供网站建设公司报价seo培训中心
  • 做网站商城需要什么独立站优化
  • 平面网页设计规范手机系统优化软件
  • 深圳网站建设网络公司合肥seo
  • 辽阳企业网站建设费汕头seo排名公司
  • php网站怎么做的重庆网站seo建设哪家好
  • 门户网站建设课程设计中国2022年重大新闻
  • 微信产品展示小程序排名优化软件
  • 慈溪网站建设随州今日头条新闻
  • 网站的域名技巧和空间选择蚁百杭州网站seo优化
  • 一个用vue做的网站疫情防控最新政策
  • 做网站需要的参考文献宁波网络推广方法
  • 泰安网站建设优化网页设计与制作学什么
  • div css 网站模板搜索关键词
  • 电脑经销部开具网站建设费阿里云域名注册
  • 怎么知道网站是某个公司做的做网站好的网站建设公司
  • 广州公司建设网站百度app下载官方免费最新版
  • 大型电子商务网站建设方案百度seo官方网站
  • 乐山市做网站的公司百度搜索广告收费标准
  • 做化妆品原料批发网站有哪些游戏推广员平台
  • 做的好的装修公司网站网站模板建站公司
  • 如何建设传奇网站百度推广按点击收费
  • 网络营销哪些公司好做呢三门峡网站seo
  • 网站开发基本要求什么企业需要网络营销和网络推广
  • 网站集约化建设优点百度客服转人工
  • 赣州seo公司东莞seo排名扣费
  • 成都网站制作收费steam交易链接在哪复制
  • api模式网站开发带佣金的旅游推广平台有哪些