主页

C++内存分配方法new与placement new使用方法详解

写在前面 总结一下C++内存分配中的new/delete方法, 以及一个很有意思的工具: placement new. 参考: cppprimer5ed, pp409, pp726(19.1). 侯捷C++ video new的基本使用 编译器角度 在使用new分配内存的时候, 例如下面这样: string *sp = new string("abc"); // 分配并初始化一个string对象 string *sa = new string[10]; // 分配10个默认初始化的string对象 上面的new内存分配, 本质上进行了三个步骤: new表达式调用一个名为operator new(或operator ne...

阅读更多

验证二叉搜索树的c++实现

写在前面 给你一个二叉树的根节点 root ,判断其是否是一个有效的二叉搜索树。 有效 二叉搜索树定义如下: 节点的左子树只包含 小于 当前节点的数。 节点的右子树只包含 大于 当前节点的数。 所有左子树和右子树自身必须也是二叉搜索树。 提示: 树中节点数目范围在$[1, 10^4]$ 内 $-2^{31} \leq Node.val \leq 2^{31} - 1$. 本质上就是中序遍历的应用, 因为二叉搜索树中序遍历的结果是一个严格的单调增序列. 第一种思路:先存数组, 然后判断 这里我一开始想的是集合去重然后判断排序数组, 但是内存飙升. class Solution { public: bool isValidBST(Tre...

阅读更多

Python与c++语法比较 字符串篇

写在前面 刷lc从Python转向C++, 不只是语法层面, 还要改变很多的API, 这次记录一下C++和Python在字符串方面的一些区别, 供参考. 基本区别 Python字符串是不可变类型, 而C++的String为容器(本质上是一个类的别名, 说容器有点不合适, 因为容器内的元素类型已经被指定为char), 可变类型. C++ 先说一下字符, 是指char类型, 其本质上也是int类型(0~127的ASCII字符, 存在隐式类型转换) using string = std::basic_string<char>; // string其实是一个类型别名 如果不需要一般的字符串操作, 可以使用vector<char>, 是一种比较纯粹的字符...

阅读更多

Macos中浏览器扩展的目录位置与扩展打包解包方法

写在前面 最近帮人下载浏览器的一个插件, 因为对方没办法访问google的插件中心, 那么就只能通过第三方扩展解压安装的方法了, 但是网上找了一圈都没有我用的浏览器的路径, 这就来总结一下路径的寻找方法吧, 以及推荐一个不错的视频嗅探插件. 环境: MacOS 12.6 浏览器:Edge, Chromium 找打包路径 Windows的Chrome应用程序支持目录的路径都在: C:\Users\USERNAME\AppData\Local\Google\Chrome\User Data\Default\Extensions 然而, MacOS的在:(Edge) /Users/USERNAME/Library/Application Support/Microso...

阅读更多

阿里云服务器安装wireshark图形界面与远程连接配置(使用tigervnc)

写在前面 昨天折腾了一下透视HTTP协议这门课的实验环境, 通过阿里云的轻量应用服务器来完成了, 但是还差一步, 那就是wireshark的安装, 虽然通过apt安装好了, 但是打不开实在是烦人, 后来经过各种搜索, 我发现问题出在了tightvnc上, 这个vnc服务器对qt程序的支持不够好, 那么接下来就来配置一下tigervnc, 这里我还用上了xfce4桌面, 感觉比gnome要舒服一些. tigervnc文档感觉不是很全, 但是用起来跟tightvnc一样顺手. 其viewer界面是FLTK开发的, 稍后可以学习一下源码. 我在Mac端使用了vnc-viewer, 但是不如tigervnc-viewer的给力, vnc-viewer需要一段时间的连接之后...

阅读更多

反转链表与链表的析构操作(c++)

写在前面 说一下反转链表的操作, 以及在生成链表之后的析构操作, 感觉这两点其实是可以联系起来记忆的. 反转链表 206. 反转链表 - 力扣(LeetCode); 一种trivial的方法当然是遍历存节点然后重新构建链表, 但是这是需要耗费$O(n)$空间的方法, 于是就有下面这种方法, 双指针记录后面未遍历的节点的方法. class Solution { public: ListNode* reverseList(ListNode* head) { ListNode *cur = head, *pre = nullptr; while (cur) { auto tmp = cur->next; ...

阅读更多

计算位1的个数方法总结

写在前面 之前介绍过一种计算整数二进制表示中位1个数的文章, 是介绍通过不断减去右移一位之后的值的方法来完成的, 后来发现还有一种更快更经典的方法, 下面来总结下. 191. 位1的个数 - 力扣(LeetCode); 各种思路 转换字符串 def calcbit1_v1(n): return bin(n).count("1") # return n.bit_count() 取最低位 def calcbit1_v2(n): ans = 0 while n: tmp = n & 1 # 取最末位 ans += tmp n >>= 1 # 进位 return ans...

阅读更多

透视http协议课程实验环境配置(基于阿里云服务器ubuntu)

写在前面 最近看看罗剑锋老师的透视HTTP协议, 折腾一下实验环境. 本来是想用mac(arm)来做的, 无奈Openresty的一个lua扩展不给力, 本地编译之后依然不行(表现为服务器错误), 所以就只能借助Intel了, 当然老师也提供了一种思路: 借助dockerfile构建基于arm的镜像实验环境(实在是因为我电脑内存不行, 不然高低折腾一下). 那么下面就开始在阿里云服务器(Ubuntu x86_64)上构建实验环境了. 主要用到的就是: Openresty (安装起来比较麻烦, 需要源码编译) telnet (apt安装即可) Firefox(或者chromium, Chrome, edge) apt安装 wireshark (apt安装, 但是打不开, 可...

阅读更多

Total views.
您是Zorch的第 个小伙伴
Hits