JRQZ

  • en

自用笔记

2024-04-12

ACM模式C++常用io

自用,ai生成 提前引入头文件 #include <bits/stdc++.h> cin cin是C++中处理标准输入的对象,属于iostream库。它用于从标准输入流(通常是键盘)读取数据。 cin会在等待用户输入时阻塞程序执行。具体来说,它在以下几种情况下会阻塞: 等待输入:当程序到达读取输入的语句,且标准输入中没有足够的数据时,cin会阻塞程序,等待用户输入数据并按下回车键。 输入缓冲区不空,但数据不足:如果输入缓冲区中有一部分数据,但不足以满足当前读取操作的需要,cin同样会阻塞,等待更多输入。 cin用作布尔表达式时,能够反映输入操作的状态: 当输入成功时,cin表达为true。 如果遇到输入结束(EOF),或者输入类型与变量类型不匹配(例如,尝试将字母读入整型变量),cin会表达为false。 cin, 作为C++标准库中的输入流对象,可以用来读取多种基本数据类型,以及一些库中定义的复合类型。这里列出了cin可以直接使用的一些常见数据类型: 基本数据类型 整数类型:int, short, long, long long,以及它们的无符号版本 unsigned int, unsigned short, unsigned long, unsigned long long。 浮点数类型:float, double, long double。 字符类型:char,以及unsigned char和signed char。 布尔类型:bool。 复合类型 字符串:std::string。读取时,cin将会读取并忽略任何前导空格(包括空格、换行符等),然后读取字符直到下一个空白字符为止。 对于大多数基本数据类型(如int、double、char等),cin使用>>操作符读取数据时,会自动跳过任何前导的空白字符,包括空格、制表符和换行符。这意味着如果输入缓冲区的开始是空白字符,cin >>会忽略它们,直到找到第一个非空白字符,并从那里开始读取输入。 getchar() getchar()函数会从输入流中读取下一个字符,并且这个字符会被消耗掉,即它会从输入流中移除,不再可用于后续的输入操作。这意味着一旦getchar()读取了一个字符,这个字符就不会再出现在输入流中,无论是cin、scanf还是其他任何读取标准输入的函数,都无法再次访问到这个字符。 getline() std::getline() 是 C++ 标准库中的一个函数,它用于从输入流中读取一行文本。std::getline() 主要与 std::istream 类型(如 std::cin、文件流等)一起使用,能够从给定的输入流中读取数据直到遇到换行符('\n'),并将读取的内容(不包括换行符)存储到一个 std::string 或其他字符序列中。 std::getline() 有几个重载版本,最常用的两个版本的签名如下: 从标准输入流读取: std::istream& getline(std::istream& is, std::string& str, char delim = '\n'); is: 输入流(如 std::cin 或文件输入流)。 str: 存储从输入流中读取的行的字符串。 delim: 可选参数,指定作为行结束符的字符,默认是换行符 '\n'。函数会读取数据直到遇到此字符为止。 从字符串流读取(属于 <sstream> 头文件):
继续阅读
2024-04-08

Hugo嵌入图片的几种方式

使用Markdown语法 ![图片替代文字](/img/jrqz/trails_in_the_sky_sc.jpg) *图片说明文本* 不支持调整大小 图片说明文本 使用HTML <figure> <img src="/img/jrqz/trails_in_the_sky_sc.jpg" alt="图片替代文字" width="50%"> <figcaption>这里是图片说明</figcaption> </figure> 需要在hugo.toml(config.toml)中添加设置 [markup.goldmark.renderer] unsafe = true 这里是图片说明 可能会导致代码注入等安全问题 使用Hugo短代码 {{< figure src="/img/jrqz/trails_in_the_sky_sc.jpg" caption="这里是图片说明" >}} 更改图片大小需要定义css样式,较为麻烦 这里是图片说明
继续阅读
2024-04-01

基于Hugo的个人博客网站搭建

基于Hugo的个人博客网站,从初始化到申请自己的独立域名,开个博客记录一下 使用Hugo在本地创建个人网站 Hugo是一个基于Go语言的开源的静态网页生成器,以轻量快速闻名,官网链接 安装 平台:Ubuntu 22.04.2 LTS(Windows Subsystem for Linux 2) 安装Go 安装Go,官方教程,安装完成后需要更新PATH,在~/.bashrc文件中添加 export PATH=$PATH:$HOME/go/bin 安装Hugo 这里使用了从源码构建的方法 CGO_ENABLED=1 go install -tags extended github.com/gohugoio/hugo@latest 等待自动安装完毕,检查Hugo是否安装成功 hugo version 创建本地网站 Hugo建站非常简单,只需使用一条命令(将jrqz替换成你的项目名称) hugo new site jrqz 刚建立的网站空空如也,所幸Hugo提供了一系列主题(theme)可供快速上手,这里使用了和官方教程相同的Anake主题 cd jrqz git init git submodule add https://github.com/theNewDynamic/gohugo-theme-ananke.git themes/ananke echo "theme = 'ananke'" >> hugo.toml 注:在以前的版本中,Hugo的配置文件名为config.toml,网上大部分教程仍旧如此 启动Hugo开发服务器,网站就创建成功了 hugo server 此时可以访问命令行提示的url查看网站 创建第一条博客 Hugo创建博客页面也非常简单,在相应位置下创建Markdown文件,hugo就可以自动将其转化为html页面 hugo new content posts/my-first-post.md 对应的文件可以看到如下内容: +++ title = 'My First Post' date = 2024-03-26T20:32:47+08:00 draft = true +++ draft = true意味着Hugo默认不会发布这篇博客。方便起见,直接将其设置为true
继续阅读
2024-03-27

算法题笔记

C++数据结构用法 通用头文件: #include <bits/stdc++.h> std::list::splice 在C++中,std::list 和 std::forward_list 容器提供了一个名为 splice 的成员函数。这个函数用于在常数时间内从一个列表转移元素到另一个列表,无需复制或移动元素,只是改变节点的指针。这使得 splice 特别高效,适用于需要重组列表元素时不引入额外性能开销的场景。 std::list::splice 函数有几个重载版本,允许你在不同的情况下使用。以下是一些最常用的重载形式: 将整个列表转移到另一个位置: cpp Copy code void splice(const_iterator pos, list& other); 这个版本将 other 列表中的所有元素转移到调用者列表中 pos 位置之前。操作后 other 为空。 将来自另一个列表的单个元素转移到指定位置: cpp Copy code void splice(const_iterator pos, list& other, const_iterator it); 这个版本只转移 other 列表中由迭代器 it 指向的单个元素到调用者列表中 pos 位置之前。 将来自另一个列表的一段元素范围转移到指定位置: cpp Copy code void splice(const_iterator pos, list& other, const_iterator first, const_iterator last); 这个版本将 other 列表中从 first 到 last(不包括 last)的元素转移到调用者列表中 pos 位置之前。
继续阅读
2024-03-26

My First Post

JRQZ的第一篇博客 蔚蓝天空—— 将一切吞噬—— 即使如此命运的齿轮也不会停止转动——
继续阅读
  • ««
  • «
  • 1
  • 2
  • 3
  • »
  • »»
© JRQZ 2026