PAT甲级备战-高精度和排序

LL calc(string n, LL r)

{

LL res = 0;

for (auto c : n)

{

if ((double)res * r + get© > 1e16) return 1e18;

res = res * r + get©;

}

return res;

}

一直输入n直到n为负数截止

while(cin>>n,n>0){

}

秦九韶算法 z = z*d+y d为需要向十进制转换的进制 y为此进制下的每一项

  • 对于读入的数据,如果需要根据数据类型进行不同的运算,比如读入的是数字就加1,如果是字母就返回ascii,那么我们可以先把数据存放到 **stringstream **里,然后再保存到其他数据类型中。

string s;

cin>>s;

stringstream ss(s);

int a;

string b;

ss>>a;

ss>>b;

排序

=====================================================================

技巧

对于模拟题,我们只需要考虑两个事情,1 怎么存数据 2 怎么模拟

round()四舍五入

count() 哈希表中查找是否存在,存在为1

容器中升降序排序

sort(Array.begin(),Array.end(),greater<类型>()); //降序

sort(Array.begin(),Array.end(),less<类型>()); //升序

或者自定义cmp函数

bool cmp(int a,int b){

return a>b;

}

sort(p[i].begin(),p[i].end(),cmp);

当使用getline读入一行时,如果前面有cin,需要使用getchar()吞掉上一个回车

getline配合stringstream可以遍历以空格为分隔的一串字符串

输入a b c d

string line;

getline(cin,line);

string key;

stringstream ss(line);

while(ss>>key)

s = ss.substr(index); 截取ss字符串index位置后的字符串给s

结构体排序 重载操作符

struct Student{

string id;

int score;

int position;

int localrank,allrank;

bool operator<(const Student& t)const{

if(score!=t.score) return score>t.score;

else return id<t.id;

}

}

定义结构体后记得写 ;

堆排序

如何手撸一个堆?

首先,堆是一个完全二叉树,且分为小根堆(子节点小于父母节点)和大根堆(子节点大于父母节点)。

那用什么来存入一个堆呢?一维数组!

对于一个一维数组a[] ,n[1]表示根节点,a[2_n]和a[2_n+1]分别为a[n]的左右子节点。

对于一个堆来说,我们有两个操作,down()操作和up()操作,这两个操作的组合(时间复杂度均为logn)可以实现对堆的一切修改。

对于小根堆:

**down()**操作:将某一个节点的值变大,堆重新调整,该节点下移

**up()**操作:将某一个节点的值变小,堆重新跳整,该节点上移

image.png

堆排序:每次输出堆顶

image.png

#include<bits/stdc++.h>

using namespace std;

const int N = 100010;

int h[N],size_;

int n,m;

void down(int u){

int t = u;

if(2u<=size_&&h[t]>h[2u]) t = 2*u;

if(2u+1<=size_&&h[t]>h[2u+1]) t = 2*u+1; //两个if找出三个节点中最小的节点,用这个节点和父节点交换

if(u!=t){

swap(h[u],h[t]);

down(t);

}

}

int main(){

cin>>n>>m;

for(int i=1;i<=n;i++){

int k;

cin>>k;

h[i] = k;

}

size_ = n;

for(int i=n/2;i;i–) down(i);

while(m–){

cout<<h[1]<<’ ';

swap(h[size_], h[1]);

size_–;

down(1);

}

return 0;

}

二分

二分模板

1.循环必须是l < r

2.if判断条件看是不是不满足条件, 然后修改上下界

3.若if else后是r = mid - 1,则前面mid 语句要加1

4.出循环一定是l == r,所以l和r用哪个都可以

二分只有下面两种情况

1:找大于等于给定数的第一个位置 (满足某个条件的第一个数)

2:找小于等于给定数的最后一个数 (满足某个条件的最后一个数)

image.png

image.png

// 判断条件很复杂时用check函数,否则if后直接写条件即可

bool check(int mid) {

return …;

}

// 能二分的题一定是满足某种性质,分成左右两部分

// if的判断条件是让mid落在满足你想要结果的区间内

最后

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数Java工程师,想要提升技能,往往是自己摸索成长,自己不成体系的自学效果低效漫长且无助。

因此收集整理了一份《2024年Java开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,不论你是刚入门Java开发的新手,还是希望在技术上不断提升的资深开发者,这些资料都将为你打开新的学习之门!

如果你觉得这些内容对你有帮助,需要这份全套学习资料的朋友可以戳我获取!!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!
链图片转存中…(img-QDr36UDm-1715866754938)]

[外链图片转存中…(img-hUTHWhBI-1715866754938)]

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,不论你是刚入门Java开发的新手,还是希望在技术上不断提升的资深开发者,这些资料都将为你打开新的学习之门!

如果你觉得这些内容对你有帮助,需要这份全套学习资料的朋友可以戳我获取!!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

  • 20
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值