今天只有一上午,讲的东西不多,这里就整理一下高精的东西,数论部分请见my blog

高精度:

先讲一讲进制问题:十进制的二进制表示:以10为例,

10的二进制表示为1010

10的三进制表示为101

将一个十进制的x转为k进制

要求把十进制的55转为三进制的表示

短除法如下:

  3|55……1

  3|18……0

  3|6……0

  3|2……2

  0

  将所有余数从下向上写出,55的三进制表示为2001

将一个k进制的数转成十进制的数

根据定义,k进制的xnxn-1xn-2……x0可以转为x·k^n+x·k^n-1+……+x·k^0

二进制、八进制、十进制、十六进制

  • 计算机中最常用的进制
  • 在C++中写一个二进制,只需要在前面加上一个前导0
  • 十六进制:用字母对应10到15(A~F),所以0x3f3f3f3f≈1.1*10^9

高精度的目的:用C++自带的类型,十进制一旦超过20位,就无法进行运算,高精度运算的目的就是通过模拟竖式加减乘除法

高精度步骤:

(1)个位对齐

    (2)逐位相加

    (3)注意进位

高精度的存储:

用数组来存每一位

以19260817为例,如果按照顺序存储,就会存成19260817。这样就不能满足个位对齐的步骤,那么我们就要反着存,即71806291,这样在做加法时个位一定是对齐的

高精度的代码(钟神的写法,只需要将int a,b转换成gaojing a,b)

  1. #include<cstdio>
  2. #include<iostream>
  3. #include<cmath>
  4. #include<cstring>
  5. using namespace std;
  6.  
  7. struct gaojing
  8. {
  9. int z[];//用来存这个数的数组,0表示个位,以此类推
  10. int l;//表示这个数是一个l位的数
  11. gaojing()
  12. {
  13. l=;
  14. memset(z,,sizeof(z));
  15. }//构造函数,每次声明一个高精类,函数都会运行一次
  16.  
  17. friend istream& operator>>(istream &cin,gaojing &a)//意思是用cin这个读入函数读入a,friend叫做有缘函数
  18. {
  19. static/*在函数中开数组的局部变量,一定要加static*/ char s[];
  20. cin>>s;
  21. int l=strlen(s);
  22. for(int i=;i<=l;++i)
  23. {
  24. a.z[i]=s[l-i-]-'';
  25. }
  26. a.l=l;
  27. return cin;//第17行和第27行当做模板记就行了
  28. }
  29.  
  30. friend ostream&operator<<(ostream &cout,const gaojing &a)
  31. {
  32. for(int i=a.l-;i>=;i--)
  33. {
  34. cout<<a.z[i];
  35. }
  36. return cout;
  37. }
  38. };
  39. //写一下需要的运算符:+ - * / % < <= > >= == != cin>> cout<<
  40. //这里只对
  41. //运用重载运算符
  42. gaojing operator+(const gaojing &a,const gaojing &b)//定义的时高精度之间的加法,不影响正常的加法,返回类型也应该是一个高精度的数
  43. //需要注意,gaojing a时,系统会对a进行备份,只在这个函数中运用,gaojing &a时,系统会直接将a的值传过来
  44. //a和b是一个高精度的东西,如果不用取址符号,将会在每一次运行函数时都拷贝一个很大很大的数组,所以在a,b前边加上&
  45. //但是如果手抖将a和b的值改动,应该加一个const(来自钟神的关爱),如果要将这个函数喂给STL,const是必不可少的
  46. {
  47. gaojing c;
  48. int l=max(a.l,b.l);
  49. for(int i=;i<l;++i)
  50. {
  51. c.z[i]=a.z[i]+b.z[i];
  52. c.z[i+]+=c.z[i]/;
  53. c.z[i]=c.z[i]%;//模拟的是进位的情况
  54. }
  55. if(c.z[l]!=) l++;
  56. c.l=l;//检查是否有进位
  57. return c;
  58. }
  59.  
  60. gaojing operator*(const gaojing &a,const gaojing &b)
  61. {
  62. gaojing c;
  63. for(int i=;i<a.l;++i)
  64. for(int j=;j<=b.l;++j)
  65. c.z[i+j]=a.z[i]*b.z[j];
  66. c.l=a.l+b.l;
  67. for(int i=;i<c.l;++i)
  68. {
  69. c.z[i+]+=c.z[i]/;
  70. c.z[i]=c.z[i]%;
  71. }
  72. while(c.l>&&c.z[c.l]==)//找第一个不等于0的c.l,这时的l为c.z[i]的长度
  73. c.l--;
  74. if(c.l==) c.l++;
  75. return c;
  76. }
  77.  
  78. int main()
  79. {
  80. gaojing x,y;
  81. cin>>x>>y;
  82. cout<<x+y<<endl<<x*y<<endl;
  83. }

清北学堂2019NOIP提高储备营DAY4的更多相关文章

  1. 清北学堂2019NOIP提高储备营DAY1

    今天是第二次培训的第一天,关于NOIP的基础算法,主要内容如下: $1.枚举 $2.搜索 $3.贪心 $1.枚举: •定义: 枚举又叫做穷举,是一种基础的算法,其思路主要是:从问题中有可能的解集中一一 ...

  2. 清北学堂2019NOIP提高储备营DAY3

    今天是钟神讲课,讲台上照旧摆满了冰红茶 目录时间到: $1. 动态规划 $2. 数位dp $3. 树形dp $4. 区间dp $5. 状压dp $6. 其它dp $1. 动态规划: ·以斐波那契数列为 ...

  3. 2017清北学堂(提高组精英班)集训笔记——动态规划Part3

    现在是晚上十二点半,好累(无奈脸),接着给各位——也是给自己,更新笔记吧~ 序列型状态划分: 经典例题:乘积最大(Luogu 1018) * 设有一个长度为 N 的数字串,要求选手使用 K 个乘号将它 ...

  4. 7月清北学堂培训 Day 3

    今天是丁明朔老师的讲授~ 数据结构 绪论 下面是天天见的: 栈,队列: 堆: 并查集: 树状数组: 线段树: 平衡树: 下面是不常见的: 主席树: 树链剖分: 树套树: 下面是清北学堂课程表里的: S ...

  5. 清北学堂2017NOIP冬令营入学测试P4745 B’s problem(b)

    清北学堂2017NOIP冬令营入学测试 P4745 B's problem(b) 时间: 1000ms / 空间: 655360KiB / Java类名: Main 背景 冬令营入学测试 描述 题目描 ...

  6. 清北学堂2017NOIP冬令营入学测试 P4744 A’s problem(a)

    清北学堂2017NOIP冬令营入学测试 P4744 A's problem(a) 时间: 1000ms / 空间: 655360KiB / Java类名: Main 背景 冬令营入学测试题,每三天结算 ...

  7. 济南清北学堂游记 Day 1.

    快住手!这根本不是暴力! 刷了一整天的题就是了..上午三道题的画风还算挺正常,估计是第一天,给点水题做做算了.. rqy大佬AK了上午的比赛! 当时我t2暴力写挂,还以为需要用啥奇怪的算法,后来发现, ...

  8. 清明培训 清北学堂 DAY1

    今天是李昊老师的讲授~~ 总结了一下今天的内容: 1.高精度算法 (1)   高精度加法 思路:模拟竖式运算 注意:进位 优化:压位 程序代码: #include<iostream>#in ...

  9. 清北学堂提高组突破营游记day4

    今天主攻图论. 对于这道题,30分做法是暴力搜索全部来判断是否有异样. 对于满分做法,利用带权并查集.? 又带我们串了一边LCA 安利个人LCA博客. spfa代码.原理:循环队列. 然后是floyd ...

随机推荐

  1. uboot启动第一阶段分析

    一. uboot第一阶段初识 1.1. 什么是uboot第一阶段 1.1.1. 启动os三个阶段 1.1.1.1. bl0阶段 a. 这段代码是三星固化到iROM中,可以查看<S5PV210_i ...

  2. Scrapy 教程(三)-网站解析

    有经验的人都知道,解析网站需要尝试,看看得到的数据是不是想要的,那么在scrapy中怎么尝试呢? 调试工具-shell 主要用于编写解析器 命令行进入shell scrapy shell url 这个 ...

  3. 四、JVM — 类文件结构

    类文件结构 一 概述 二 Class 文件结构总结 2.1 魔数 2.2 Class 文件版本 2.3 常量池 2.4 访问标志 2.5 当前类索引,父类索引与接口索引集合 2.6 字段表集合 2.7 ...

  4. easyui 前端分页及前端查询

    1.静态分页核心方法 // 前端分页 -- 将datagrid的loadFilter属性设置为这个方法名即可 function partPurchasePagerFilter(data) { if ( ...

  5. HBase Shell 的常用操作总结

      1,创建表:create 't1','f1','f2','f3'                   #-------t1是表名,f1,f2,f3是列族名   2,查看所有的表:list   3, ...

  6. k3 cloud中如何把一个账套中的单据部署到另一个账套中

    打开bos,依次点击->解决方案->部署包管理 填写部署包名称并点击下一步 选择需要部署的单据并点击下一步 确定后点击下一步: 点击完成 找到部署路径会成一个部署包: 部署:打开部署包安装 ...

  7. vscode 热部署 spring-mvc

    1.添加maven插件 <plugin> <groupId>org.apache.maven.plugins</groupId> <artifactId> ...

  8. 关于spring 获取不到网站上的xsd的处理记录

    前两天做一个项目还好好的,今天突然报出这个错误 cvc-complex-type.2.4.c: The matching wildcard is strict, but no declaration ...

  9. EffectiveC++条款04:确定对象被使用前已先被初始化

    不要混淆赋值和初始化,对于大多数类型而言,比起先调用默认构造函数然后调用赋值操作符,只调用一次拷贝构造函数是高效的 对于内置类型,也需要成员初值列(member initialization list ...

  10. 与Swing的相识

    参考自http://c.biancheng.net/swing/ Swing是一个用于Java GUI编程(图形界面设计)的工具包(类库):换句话说,java可以用来开发带界面的PC软件,使用到的工具 ...