C标准库常用函数

memset函数:暴力清空

void *memset(void *str, int c, size_t n)
  • str -- 指向要填充的内存块。

  • c -- 要被设置的值。该值以 int 形式传递,但是函数在填充内存块时是使用该值的无符号字符形式。

  • n -- 要被设置为该值的字符数。

    char str[10];
memset(str,0,sizeof(str));

memcpy:暴力拷贝

void *memcpy(void *str1, const void *str2, size_t n)
  • str1 -- 指向用于存储复制内容的目标数组,类型强制转换为 void* 指针。

  • str2 -- 指向要复制的数据源,类型强制转换为 void* 指针。

  • n -- 要被复制的字节数。

    char src[50]="please help child!";
char t[50];
memcpy(t,src,strlen(src)+1);//存在一个问题,最后一个参数+1后不会乱码,不+就会乱,这为啥
printf("t = %s\n", t);

strcpy:字符串拷贝

//so easy...Lazy

strcmp:字符串比较

//so easy...Lazy

strlen:字符串长度

//so easy...Lazy

rand:随机数和随机字符

    srand((unsigned)time(0));//根据系统时间设置随机数种子
   rand();//产生一个0-65535的随机数,
  (rand() % (b-a))+ a;//[a,b) 的随机整数
  (rand() % (b-a+1))+ a;//要取得 [a,b] 的随机整数,使用
  (rand() % (b-a))+ a + 1;//要取得 (a,b] 的随机整数,使用
   rand() / double(RAND_MAX)//要取得 0~1 之间的浮点数,可以使用
    char f[52];
   strcpy( f, "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ");
   srand((unsigned)time(NULL) * 10);
   f[rand()%52];//产生随机字符

complex复数类

数学运算时懒的写定义时候用的

C++常用STL知识

vector容器

三种遍历方式

  • 下标遍历,就像数组那样

  • 迭代器遍历,类似指针

  • algorthm中提供的for_each遍历算法

存放自定义类型

容器嵌套容器

注意:需要先建立容器,在把容器放进容器,不能之间嵌套

//1.构造容器
vector<int> arr{1,4,2,5,6,3,5,3,74};//奇奇怪怪的构造+定义
vector<T> v; //采用模板实现类实现,默认构造函数
vector(v.begin(), v.end()); //将v[begin(), end())区间中的元素拷贝给本身。
vector(n, elem); //构造函数将n个elem拷贝给本身。
vector(const vector &vec); //拷贝构造函数。

//2.赋值
assign(beg, end); //将[beg, end)区间中的数据拷贝赋值给本身。
assign(n, elem); //将n个elem拷贝赋值给本身。

//3.判断
size(); //返回容器中元素的个数
empty(); //判断容器是否为空

//4.插入删除
push_back(ele); //尾部插入元素ele
pop_back(); //删除最后一个元素
insert(const_iterator pos, ele); //迭代器指向位置pos插入元素ele
insert(const_iterator pos, int count,ele); //迭代器指向位置pos插入count个元素ele
erase(const_iterator pos); //删除迭代器指向的元素
erase(const_iterator start, const_iterator end); //删除迭代器从start到end之间的元素
clear(); //删除容器中所有元素

vector预留空间可以减少vector在动态扩展容量时的扩展次数

reserve(int len); //容器预留len个元素长度,预留位置不初始化,元素不可访问。

String容器

绝不是我摸鱼才不写的,我之后在填坑复习....

List容器

绝不是我摸鱼才不写的,我之后在填坑复习....

set/ multiset 容器

map/ multimap容器

其他

<unordered_map>和<unordered_set>

set和map的另一种实现版本,用起来和set和map没啥区别都是基于哈希的可以O(1)的访问和删除一个元素,但是不允许按大小排序

用于卡map时间的题

bitset位集合

只由0和1组成的数组,可以和数组一样用下标访问,也可以位运算,

用于状态压缩动态规划

algorithm常用算法

for_each(iterator beg, iterator end, _func);//遍历算法

常用排序算法

int cmp(int a, int b)  {  return a>b; }
sort(arr.begin(),arr.end());//默认的从小到大排序
sort(vec1.begin(), vec1.end(),cmp);//定义谓词,从大到小排列
reverse(arr.begin(),arr.end());//反转容器
merge(v1.begin(), v1.end(), v2.begin(), v2.end(), vtarget.begin());//合并容器

常用查找算法

vector<int>::iterator it = find(v.begin(), v.end(), 5);//注意返回值为迭代器


#include<bits/stdc++.h>
using namespace std;

class cmp{
public:
bool operator()(int val){
return val > 5;
}
};

vector<int> arr {3,2,4,5,7};
int main(void){
vector<int>::iterator it = find_if(arr.begin(),arr.end(),cmp());
if(it == arr.end()){
cout<<"没有找到"<<endl;
}else{
cout<< *it<<endl;
}
return 0;
}
bool ret = binary_search(v.begin(), v.end(),2);//二分查找算法:注意查找的容器需要为有序序列
int num = count(v.begin(), v.end(), 4);//统计元素个数

min_element

max_element

nth_element

算法竞赛细节:

1s时限运算大概1e8,根据复杂度来计算是否超时;

输出double时有时用%lf会WA到哭,所以用%f输出;

初始化的常数时间也得估计好

const int INF = 0x3f3f3f;//表示无穷大值
memset(arr,INF,sizeof(arr));//令数组初始化为无穷大

1e5以上的时间用cin就可能会有问题,最好使用scanf和printf

快速签到判断EOF

while(cin>>a){}

竞赛万能头代码

#include<bits/stdc++.h>

蓝桥杯赛前复习C++的更多相关文章

  1. 资料整理,SQL Server ,面试前复习笔记

    T-SQL 要掌握的知识点分类 SQL 面向数据库执行查询 SQL 从数据库取回数据 SQL 在数据库中插入新的记录 SQL 更新数据库中的数据 SQL 从数据库删除记录 SQL 创建新数据库 SQL ...

  2. 2020年大厂Java面试前复习的正确姿势(800+面试题附答案解析)

    前言 个人觉得面试也像是一场全新的征程,失败和胜利都是平常之事.所以,劝各位不要因为面试失败而灰心. 丧失斗志.也不要因为面试通过而沾沾自喜,等待你的将是更美好的未来,继续加油! 本篇分享的面试题内容 ...

  3. 蓝桥杯-加法变乘法-java

    /* (程序头部注释开始) * 程序的版权和版本声明部分 * Copyright (c) 2016, 广州科技贸易职业学院信息工程系学生 * All rights reserved. * 文件名称: ...

  4. 蓝桥杯-大衍数列-java

    /* (程序头部注释开始) * 程序的版权和版本声明部分 * Copyright (c) 2016, 广州科技贸易职业学院信息工程系学生 * All rights reserved. * 文件名称: ...

  5. 蓝桥杯-第39级台阶-java

    /* (程序头部注释开始) * 程序的版权和版本声明部分 * Copyright (c) 2016, 广州科技贸易职业学院信息工程系学生 * All rights reserved. * 文件名称: ...

  6. 蓝桥杯-手机尾号-java

    /* (程序头部注释开始) * 程序的版权和版本声明部分 * Copyright (c) 2016, 广州科技贸易职业学院信息工程系学生 * All rights reserved. * 文件名称: ...

  7. 蓝桥杯-放麦子-java

    /* (程序头部注释开始) * 程序的版权和版本声明部分 * Copyright (c) 2016, 广州科技贸易职业学院信息工程系学生 * All rights reserved. * 文件名称: ...

  8. 蓝桥杯-n级台阶-java

    /* (程序头部注释开始) * 程序的版权和版本声明部分 * Copyright (c) 2016, 广州科技贸易职业学院信息工程系学生 * All rights reserved. * 文件名称: ...

  9. 蓝桥杯-四平方和-java

    /* (程序头部注释开始) * 程序的版权和版本声明部分 * Copyright (c) 2016, 广州科技贸易职业学院信息工程系学生 * All rights reserved. * 文件名称: ...

随机推荐

  1. 记Windows服务器Redis 6379被攻击 被设置主从模式同步项目数据

    在工作中第一次经历被攻击,我是一个前端,同时复负责维护一个已上线的项目,在最近一段时间小程序与后台经常出现这个报错, 搜了下说我的从机是只读模式,不能写入,问了同事得知这个项目是单机模式,根本不存在从 ...

  2. 048_末晨曦Vue技术_处理边界情况之使用$root访问根实例

    处理边界情况之使用$root访问根实例 点击打开视频教程 在每个 new Vue 实例的子组件中,其根实例可以通过 $root property 进行访问. 例如,在这个根实例中: src\main. ...

  3. mybatis 15: 缓存

    作用 当对某些数据的查询请求频繁,且数据不经常修改时,使用缓存机制可以提高查询效率 注意 mybatis专注于sql查询,数据映射 缓存问题应该交给专门负责缓存的其他第三方框架 mybatis缓存执行 ...

  4. 基础1:JS的原型和原型链究竟

    JS的原型和原型链究竟是什么? 1. 从JS创建一个对象开始说起: 1.1 工厂模式创建对象 (缺点是无法知道创建出来的对象是一个什么类型的对象) function createPerson(name ...

  5. 并发与并行,同步和异步,Go lang1.18入门精炼教程,由白丁入鸿儒,Go lang并发编程之GoroutineEP13

    如果说Go lang是静态语言中的皇冠,那么,Goroutine就是并发编程方式中的钻石.Goroutine是Go语言设计体系中最核心的精华,它非常轻量,一个 Goroutine 只占几 KB,并且这 ...

  6. 关于使用docker volume挂载的注意事项

    Content 在用Docker进行持久化的存储的时候,有两种方式: 使用数据卷(volume) -v 容器绝对路径 或者 -v 已经创建的volume名称:容器绝对路径 2. 使用挂载点(共享宿主目 ...

  7. 总在用户态调试 C# 程序,终还是搭了一个内核态环境

    一:背景 一直在用 WinDbg 调试用户态程序,并没有用它调试过 内核态,毕竟不是做驱动开发,也没有在分析 dump 中需要接触用内核态的需求,但未知的事情总觉得很酷,加上最近在看 <深入解析 ...

  8. Skype for Business server 数据库安装

    之前安装了SFB 2015标准版,但是没有安装归档据库,现在打算重新安装.环境中安装的是默认自带的SQL EXPRESS. 继续安装向导,安装SQL数据库.但是在最后的时候遇到了问题. 安装向导报错 ...

  9. IEEE浮点数向偶数舍

    CSAPP ​ 向偶数舍入初看上去好像是个相当随意的目标--有什么理由偏向取偶数呢?为什么不始终把位于两个可表示的值中间的值都向上舍入呢?使用这种方法的一个问题就是很容易假想到这样的情景:这种方法舍入 ...

  10. (五)JPA - 原生SQL实现增删改查

    6.原生SQL JPA除了对JPQL提供支持外,还对原生SQL语句也提供了支持.下面小节一起来看看吧. 6.1 查询单个 示例代码: @Test public void getSingle() { E ...