Qeuroal's Blog

静幽正治

  1. 程序设计返回结果

    1. Accepted: 通过
    2. Wrong Answer: 答案错误
    3. Runtime Error: 表示程序因为非法访问或未处理异常而结束。
    4. Memory Limit Exceeded: 表示程序因为使用的内存超过规定的内存限制。
    5. Presentation Error: 表示虽然程序输出的答案是对的,但是换行或空格等不符合输出格式要求
    6. Time Limit Exceed: 超时
    7. Output Limit Exceeded: 表示程序输出了过多的内容。
    8. Compile Error: 表示所提交的源代码没能通过编译,不符合语法规定。
    9. System Error, Validator Error: 表示系统发生错误无法正常判题。
    10. Segmentation Fault: 段错误:访问的内存超过了系统所给这个程序的内存空间
  2. 状态

    例子:找最短路径的问题中,状态仅仅是目前所在位置的坐标。

    当状态更加复杂是,就需要封装成一个类来表示转态了。

  3. 状态转移、转移的方式

    例子:同1中的例子,转移的方式为4个方向移动

    又如:八连通($P_{32}$),8个方向共对应了8种状态转移。

  4. next_permutation 函数使用

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    #include <iostream>
    #include <algorithm>
    using namespace std;
    int main()
    {
    int a[4] = {1, 5, 4, 3}, i;
    sort(a, a + 4); //在使用全排列函数之前,一定要先将数组中的数排序哦(不排序好像也可以)
    do {
    for (i = 0; i < 4; i++) cout << a[i] << " ";
    cout << endl;
    } while (next_permutation(a, a + 3));

    for (i = 0; i < 4; i++) cout << a[i] << " ";
    return 0;
    }

    使用 next_permutation 后,原数组的不变。

  5. 贪心算法

    贪心算法就是遵循某种规则,不断贪心地选取当期那最优策略的算法设计方法。

    如果我们不慎重地选择一个正确的规则,就会得到错误的算法。

    如果问题能够用贪心算法来求解的话,那么它通常是非常高效的。

    1. 区间问题:在可选工作中,每次都选择结束时间最早的工作。
    2. 字典序比较类型的问题经常用得上贪心法
  6. 动态规划

    1. 记忆化搜索

      在需要剪枝的情况下,可能会把各种参数都写在函数上,但是这种情况下会让记忆化搜索难以实现,需要注意

    2. def

      一步步按顺序求出问题的解的方法。

  7. memset 初始化数组

    语法: memset(<数组名>, <初始化的值>, <数组的大小>)

    虽然 memset 按照1字节为单位对内存进行填充,-1的每一位二进制位都为1,所以不可以像0一样用 memset 进行初始化。通过使用 Memset 可以快速地对高维数组等进行初始化,但是需要注意无法初始化成1之类的数值。

  8. 移位运算

    1. $1 << n = 2^n$
    2. $n << 1 = 2n$
    3. $n >> 1 = \lfloor{\frac{n}{2.0}}\rfloor$
  9. $a^b$ 算法

    求a的b次方对p取模的值,其中 $1 \leq a, b, p \leq 10^9$

    1
    2
    3
    4
    5
    6
    7
    8
    int power(int a, int b, int p) {
    int ans = 1 % p;
    for (; b; b >>= 1) {
    if (b & 1) ans = 1ll *ans * a % p;
    a = 1ll * a * a % p;
    }
    return ans;
    }
  10. $a * b % p$

    求a乘b对p取模的值,其中 $1 \leq a, b, p \leq 10^{18}$

    1. 方法一
      1
      2
      3
      4
      5
      6
      7
      8
      long long mul(long long a, long long b, long long p) {
      long long ans = 0;
      for (; b; b >>= 1) {
      if (b & 1) ans = (ans + a) % p;
      a = a * 2 % p;
      }
      return ans;
      }
    2. 方法二 ($P_6$)
      1
      2
      3
      4
      long long mul(long long a, long long b, long long p) {

      }

  11. 二进制状态压缩

    操作 运算
    取出整数n在二进制表示下的第k位 (n >> k) & 1
    取出整数n在二进制表示下的第0 ~ k - 1位(后k位) n & ((1 << k) - 1)
    把整数n在二进制表示下的第k位取反 n xor (1 << k)
    对整数n在二进制表示下的第k位赋值为1 n | (1<<k)
    对整数n在二进制表示下的第k为赋值为0 n & (~(1 << k))

  1. 新建 shadowsocks.desktop

  2. 将以下内容根据自己的情况更改,复制到 shadowsocks.desktop 内:

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    [Desktop Entry]
    Version=1.0
    Type=Application
    Name=Shadowsocks
    Comment=Connection Manager — Shadowsocks-Qt5
    Exec=/home/gph/shadowsocks_ubuntu/Shadowsocks-Qt5-3.0.1-x86_64.AppImage // AppImage程序路径
    Icon=/home/gph/shadowsocks_ubuntu/shadowsocks.png // 小飞机的图标
    Terminal=false
    StartupNotify=true
    Categories=Application
  3. 即创建快捷方式

Note: 如果没有创建快捷方式,好像应该不能开机自启。

PE

微PE工具箱

步骤

  1. 使用U盘启动快捷项,启动PE
  2. 在分区大师工具看下自己ESP在哪个盘符,就在UEFI引导修复里面选择哪个盘符。
    ./105/10.png)
  3. 开UEFI引导修复,在ESP里面选择H盘符(若没有则点击 挂载
    ./105/11.png)
  4. 选择根目录:windows目录(例:C:\Windows
  5. 点击开始修复,点击确定
  6. 最后重新开机,就可以进入系统了

准备工作

步骤

  1. 右击系统镜像 - 挂载

  2. 将下载的WTG解压出来,然后运行

  3. 按照下图进行设置

    • 点击 浏览... ,选择挂载的 系统镜像的目录 -> sources -> install.wim
    • 选择安装的系统的U盘,即 浏览... 下面一栏(左面第二栏)
    • 再下面一栏(左面第三栏),选择要安装系统的版本(推荐:专业版或企业版)
    • 高级选项(右面)- 常用:选择: UEFI+MBR,其他的根据自己的需求来选择
  4. 然后,使用U盘快捷启动进入系统就可以了

**【Note】:**如果原来系统的打不开了,即引导出了问题,见下一篇文章(UEFI引导修复)

进入tmux翻屏模式

  • 先按 Ctrl+q,松开,然后再按 [
  • 实现上下翻页: 进入翻屏模式后,PgUp, PgDn 实现上下翻页
  • 退出: q

ps: ctrl + b + [,很多人会以为是同时按三个键,但是这样是不行的。

简单介绍下tmux的其他功能

常用快捷键

Tmux快捷指令

关于快捷指令,首先要认识到的是:tmux的所有指令,都包含同一个前缀,默认为Ctrl+q,输入完前缀过后,控制台激活,命令按键才能生效。前面tmux会话相关的操作中,我们共用到了两个快捷键Ctrl+q + dCtrl+q + s,但这仅仅是冰山一角,欲窥tmux庞大的快捷键体系,请看下表。

Note: prefix: Ctrl+q

系统指令

前缀 指令 描述
Ctrl+q ? 显示快捷键帮助文档
Ctrl+q d 断开当前会话
Ctrl+q D 选择要断开的会话
Ctrl+q Ctrl+z 挂起当前会话
Ctrl+q r 强制重载当前会话
Ctrl+q s 显示会话列表用于选择并切换
Ctrl+q : 进入命令行模式,此时可直接输入ls等命令
Ctrl+q [ 进入复制模式,按q退出
Ctrl+q ] 粘贴复制模式中复制的文本
Ctrl+q ~ 列出提示信息缓存
Ctrl+q $ 重名名当前会话

窗口(window)指令。

前缀 指令 描述
Ctrl+q c 新建窗口
Ctrl+q & 关闭当前窗口(关闭前需输入y or n确认)
Ctrl+q 0~9 切换到指定窗口
Ctrl+q p 切换到上一窗口
Ctrl+q n 切换到下一窗口
Ctrl+q w 打开窗口列表,用于且切换窗口
Ctrl+q , 重命名当前窗口
Ctrl+q . 修改当前窗口编号(适用于窗口重新排序)
Ctrl+q f 快速定位到窗口(输入关键字匹配窗口名称)

表三:面板(pane)指令。

前缀 指令 描述
Ctrl+q " 当前面板上下一分为二,下侧新建面板
Ctrl+q % 当前面板左右一分为二,右侧新建面板
Ctrl+q x 关闭当前面板(关闭前需输入y or n确认)
Ctrl+q z 最大化当前面板,再重复一次按键后恢复正常(v1.8版本新增)
Ctrl+q ! 将当前面板移动到新的窗口打开(原窗口中存在两个及以上面板有效)
Ctrl+q ; 切换到最后一次使用的面板
Ctrl+q q 显示面板编号,在编号消失前输入对应的数字可切换到相应的面板
Ctrl+q { 向前置换当前面板
Ctrl+q } 向后置换当前面板
Ctrl+q Ctrl+o 顺时针旋转当前窗口中的所有面板
Ctrl+q 方向键 移动光标切换面板
Ctrl+q o 选择下一面板
Ctrl+q 空格键 在自带的面板布局中循环切换
Ctrl+q Alt+方向键 以5个单元格为单位调整当前面板边缘
Ctrl+q Ctrl+方向键 以1个单元格为单位调整当前面板边缘(Mac下被系统快捷键覆盖)
Ctrl+q t 显示时钟

tmux的丝滑分屏功能正是得益于以上系统、窗口、面板的快捷指令,只要你愿意,你就可以解除任意的快捷指令,然后绑上你喜欢的指令,当然这就涉及到它的可配置性了。

补充

快捷键 功能
Ctrl+q % 竖直拆分屏幕(两个 Shell 分别位于左右)
Ctrl+q " 水平拆分屏幕(两个 Shell 分别位于上下)
Ctrl+q O 切换到另一个 Shell
Ctrl+q ? 查看帮助
Ctrl+q d 断开 tmux 并让其在后台运行(可以使用 tmux attach 重新进入)
Ctrl+q <arrow key> 光标切换到其他窗格 <arrow key> 是指向要切换到的窗格的方向键
比如切换到下方窗格,就按方向键↓
Ctrl+q ; 光标切换到上一个窗格
Ctrl+q o 光标切换到下一个窗格
Ctrl+q { 当前窗格与上一个窗格交换位置
Ctrl+q } 当前窗格与下一个窗格交换位置
Ctrl+q Ctrl+o 所有窗格向前移动一个位置,第一个窗格变成最后一个窗格
Ctrl+q Alt+o 所有窗格向后移动一个位置,最后一个窗格变成第一个窗格
Ctrl+q x 关闭当前窗格
Ctrl+q ! 将当前窗格拆分为一个独立窗口
Ctrl+q z 当前窗格全屏显示,再使用一次会变回原来大小
Ctrl+q Ctrl+<arrow key> 按箭头方向调整窗格大小
Ctrl+q q 显示窗格编号
prefix Ctrl+q 激活控制台;此时以下按键生效
系统操作 ? 列出所有快捷键;按q返回
d 脱离当前会话;这样可以暂时返回Shell界面,输入tmux attach能够重新进入之前的会话
D 选择要脱离的会话;在同时开启了多个会话时使用
Ctrl+z 挂起当前会话
r 强制重绘未脱离的会话
s 选择并切换会话;在同时开启了多个会话时使用
: 进入命令行模式;此时可以输入支持的命令,例如kill-server可以关闭服务器
[ 进入复制模式;此时的操作与vi/emacs相同,按q/Esc退出
~ 列出提示信息缓存;其中包含了之前tmux返回的各种提示信息
窗口操作 c 创建新窗口
& 关闭当前窗口
数字键 切换至指定窗口
p 切换至上一窗口
n 切换至下一窗口
l 在前后两个窗口间互相切换
w 通过窗口列表切换窗口
, 重命名当前窗口;这样便于识别
. 修改当前窗口编号;相当于窗口重新排序
f 在所有窗口中查找指定文本
面板操作 将当前面板平分为上下两块
% 将当前面板平分为左右两块
x 关闭当前面板
! 将当前面板置于新窗口;即新建一个窗口,其中仅包含当前面板
Ctrl+方向键 以1个单元格为单位移动边缘以调整当前面板大小
Alt+方向键 以5个单元格为单位移动边缘以调整当前面板大小
Space 在预置的面板布局中循环切换;依次包括even-horizontal、even-vertical、main-horizontal、main-vertical、tiled
q 显示面板编号
o 在当前窗口中选择下一面板
方向键 移动光标以选择面板
{ 向前置换当前面板
} 向后置换当前面板
Alt+o 逆时针旋转当前窗口的面板
Ctrl+o 顺时针旋转当前窗口的面板

创建tmux

1
$ tmux new -s <session-name>

列出已有的tmux列表

  • 命令

    1
    2
    3
    $ tmux ls
    # or
    $ tmux list-session
  • Ctrl+q s:列出所有会话。

进入已创建的tmux

  • 使用会话编号

    1
    2
    3
    $ tmux attach -t <session-number>
    # or
    $ tmux a -t <session-number>
  • 使用会话名称

    1
    2
    3
    $ tmux attach -t <session-name>
    # or
    $ tmux a -t <session-name>

切换会话

1
2
3
4
5
# 使用会话编号
$ tmux switch -t <session-number>

# 使用会话名称
$ tmux switch -t <session-name>

重命名会话

  • $ tmux rename-session命令用于重命名会话。

    1
    $ tmux rename-session -t <session-number> <new-name>

    上面命令将<session-number>号会话重命名。

  • Ctrl+q $

临时退出tmux

  • Ctrl+q d
  • $ tmux detach

杀死tmux

  • tmux外:$ tmux kill-session -t <session-name>

  • tmux内:

    • Ctrl-d
    • <Prefix(ctrl+q)> + :kill-session

删除所有tmux

1
2
3
tmux kill-server

tmux ls | grep : | cut -d. -f1 | awk '{print substr($1, 0, length($1)-1)}' | xargs kill

vi-mode

vi emacs 功能
^ M-m 反缩进
Escape C-g 清除选定内容
Enter M-w 复制选定内容
j Down 光标下移
h Left 光标左移
l Right 光标右移
L 光标移到尾行
M M-r 光标移到中间行
H M-R 光标移到首行
k Up 光标上移
d C-u 删除整行
D C-k 删除到行末
$ C-e 移到行尾
: g 前往指定行
C-d M-Down 向下滚动半屏
C-u M-Up 向上滚动半屏
C-f Page down 下一页
w M-f 下一个词
p C-y 粘贴
C-b Page up 上一页
b M-b 上一个词
q Escape 退出
C-Down or J C-Down 向下翻
C-Up or K C-Up 向下翻
n n 继续搜索
? C-r 向前搜索
/ C-s 向后搜索
0 C-a 移到行首
Space C-Space 开始选中
C-t 字符调序
0%