【十四】【C++】list 的常见用法

list 的初始化和遍历

 
/*list的初始化和遍历*/
#if 1
#include <list>
#include <vector>
#include <iostream>
#include<algorithm>
using namespace std;void TestList1(){list<int> L1;list<int> L2(10, 5);vector<int> v{1,2,3,4,5};list<int> L3(v.begin(), v.end());list<int> L4(L3);// C++11list<int> L5{ 1, 2, 3, 4, 5 };/// 链表遍历for (auto e : L2)cout << e << " ";cout << endl;// list<int>::iterator it = L3.begin();auto it = L3.begin();while (it != L3.end()){cout << *it << " ";++it;}cout << endl;auto rit = L4.rbegin();while (rit != L4.rend()){cout << *rit << " ";++rit;}cout << endl;// 注意:list不能使用原生态指针,即Node*来遍历链表// 因为list没有提供获取头指针的方法
}int main(){TestList1();}
#endif

std::list 是一个双向链表,提供了双向序列的特性,包括有效地进行插入、删除操作等,但不支持随机访问。

初始化 std::list

空初始化: list<int> L1; 创建了一个空的 int 类型的 list

填充初始化: list<int> L2(10, 5); 创建了一个包含 10 个元素,每个元素都初始化为 5 的 list

范围初始化: list<int> L3(v.begin(), v.end()); 使用 vector<int> v 的迭代器范围来初始化 L3,即将 v 中的元素复制到 L3 中。

拷贝初始化: list<int> L4(L3); 使用另一个 list L3 来初始化 L4,复制 L3 的所有元素。

列表初始化 (C++11): list<int> L5{ 1, 2, 3, 4, 5 }; 使用初始化列表直接初始化 L5

链表遍历

范围 for 循环: 使用范围 for 循环遍历 L2,打印出其所有元素。这是 C++11 引入的一种简洁的遍历容器的方式。

使用迭代器: 通过迭代器 it 遍历 L3,同样打印出所有元素。std::list 提供的迭代器是双向迭代器。

使用反向迭代器: 通过反向迭代器 rit 遍历 L4,但这次是逆序打印出所有元素。反向迭代器从容器的末尾开始遍历至开始。

注意

代码中提到,“list不能使用原生态指针,即 Node*来遍历链表”,这是因为 std::list 的实现细节被抽象化了,用户无法像操作普通链表那样通过节点指针进行遍历或访问。std::list 提供了迭代器来抽象这些细节,使得操作更安全、更容易。

list 的 resize 操作探究

 
/*list的resize操作探究*/
#if 1
#include <list>
#include <vector>
#include <iostream>
#include<algorithm>
using namespace std;void TestList2(){list<int> L{ 1, 2, 3, 4, 5 };cout << L.size() << endl;L.resize(10, 6);for (auto e : L)cout << e << " ";cout << endl;L.resize(20);for (auto e : L)cout << e << " ";cout << endl;L.resize(7);for (auto e : L)cout << e << " ";cout << endl;}int main(){TestList2();}
#endif

resize 方法用于调整链表的大小,即元素的数量。以下是对 TestList2 函数中各个操作的详细解释:

初始化 std::list

list<int> L{ 1, 2, 3, 4, 5 };

使用初始化列表创建了一个包含元素 {1, 2, 3, 4, 5}list

调整大小并填充新元素

L.resize(10, 6);

调整 L 的大小至 10 个元素。由于新大小大于当前大小,resize 方法会添加额外的元素。在这个例子中,新增的元素被初始化为 6。因此,调整后的 list 包含元素 {1, 2, 3, 4, 5, 6, 6, 6, 6, 6}

再次调整大小,使用默认值填充

L.resize(20);

这次 L 的大小被调整至 20 个元素。因为没有指定新元素的初始化值,新增的元素会被默认初始化。对于整数类型,这意味着它们被初始化为 0。现在,list 包含 {1, 2, 3, 4, 5, 6, 6, 6, 6, 6, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0}

减少 list 的大小

L.resize(20);

L 的大小被减少至 7 个元素。resize 方法会移除超出新大小的元素。因此,list 现在包含 {1, 2, 3, 4, 5, 6, 6}

在每次调整大小之后,代码通过一个范围 for 循环遍历 L 并打印其所有元素,这样可以直观地看到 resize 操作的结果。

list 的插入删除操作探究

 
/*list的插入删除操作探究*/
#if 1
#include <list>
#include <vector>
#include <iostream>
#include<algorithm>
using namespace std;void TestList3(){list<int> L{ 1, 2, 3, 4, 5 };L.push_back(6);L.push_back(7);L.push_back(8);L.push_back(9);cout << L.size() << endl;cout << L.front() << endl;cout << L.back() << endl;L.pop_back();L.pop_back();for (auto e : L)cout << e << " ";cout << endl;L.push_front(0);for (auto e : L)cout << e << " ";cout << endl;L.pop_front();for (auto e : L)cout << e << " ";cout << endl;L.insert(L.begin(), 0);auto pos = find(L.begin(), L.end(), 5);if (pos != L.end())L.insert(pos, 5, 8);int array[] = { 10, 20, 30, 40, 50 };L.insert(L.end(), array, array + sizeof(array) / sizeof(array[0]));}int main(){TestList3();}
#endif

std::list 是一个双向链表,支持在任何位置高效插入和删除元素。

初始化 std::list

list<int> L{ 1, 2, 3, 4, 5 };

使用初始化列表创建了一个包含元素 {1, 2, 3, 4, 5} 的链表 L

添加元素到链表尾部

通过 push_back 方法,在链表的尾部依次添加了元素 6789

L.push_back(6);

L.push_back(7);

L.push_back(8);

L.push_back(9);

这些操作将 L 扩展为 {1, 2, 3, 4, 5, 6, 7, 8, 9}

移除链表尾部的元素

通过 pop_back 方法移除了链表尾部的两个元素(89)。

L.pop_back();

L.pop_back();

L 现在包含 {1, 2, 3, 4, 5, 6, 7}

在链表头部添加元素

通过 push_front 方法在链表的头部添加了元素 0

L.push_front(0);

L 现在包含 {0, 1, 2, 3, 4, 5, 6, 7}

移除链表头部的元素

通过 pop_front 方法移除了链表头部的元素 0

L.pop_front();

L 恢复为 {1, 2, 3, 4, 5, 6, 7}

在链表特定位置插入元素

首先,在链表的开始位置插入元素 0

L.insert(L.begin(), 0);

然后,找到元素 5 的位置,并在该位置前插入五个 8

auto pos = find(L.begin(), L.end(), 5);

if (pos != L.end())

L.insert(pos, 5, 8);

这使得 L 变为 {0, 1, 2, 3, 4, 8, 8, 8, 8, 8, 5, 6, 7}

从数组中插入多个元素

通过 insert 方法,将一个整型数组 {10, 20, 30, 40, 50} 的所有元素插入到链表的末尾。

int array[] = { 10, 20, 30, 40, 50 };

L.insert(L.end(), array, array + sizeof(array) / sizeof(array[0]));

这将数组中的元素添加到了 L 的末尾,使得 L 最终包含 {0, 1, 2, 3, 4, 8, 8, 8, 8, 8, 5, 6, 7, 10, 20, 30, 40, 50}

list 的 erase、assign 操作探究

 
/*list的erase、assign操作探究*/
#if 1
#include <list>
#include <vector>
#include <iostream>
#include<algorithm>
using namespace std;void TestList4(){list<int> L{ 1, 2, 3, 4, 5 };L.push_back(6);L.push_back(7);L.push_back(8);L.push_back(9);L.erase(L.begin());L.erase(find(L.begin(), L.end(), 8));L.erase(L.begin(), L.end());    // clear();L.assign(10, 5);int array[] = { 10, 20, 30, 40, 50 };L.assign(array, array + sizeof(array) / sizeof(array[0]));}int main(){TestList4();}
#endif

初始链表的创建和元素添加

list<int> L{ 1, 2, 3, 4, 5 };

L.push_back(6);

L.push_back(7);

L.push_back(8);

L.push_back(9);

首先,通过初始化列表创建一个包含 {1, 2, 3, 4, 5}list,然后依次添加元素 6789 到链表的末尾,使得链表变为 {1, 2, 3, 4, 5, 6, 7, 8, 9}

删除链表中的元素

L.erase(L.begin());

删除链表的第一个元素(1)。此时链表变为 {2, 3, 4, 5, 6, 7, 8, 9}

L.erase(find(L.begin(), L.end(), 8));

使用 find 函数查找值为 8 的元素,并将其删除。此时链表变为 {2, 3, 4, 5, 6, 7, 9}

L.erase(L.begin(), L.end()); // clear();

删除链表中从开始到结束的所有元素,相当于清空整个链表。这行代码实际上清空了链表,使其不包含任何元素。

重新分配链表内容

L.assign(10, 5);

assign 方法用于将链表的内容替换为指定数量(这里是 10)的重复元素(这里是 5)。执行这个操作后,链表包含了 10 个值为 5 的元素。

使用数组重新分配链表内容

int array[] = { 10, 20, 30, 40, 50 };

L.assign(array, array + sizeof(array) / sizeof(array[0]));

再次使用 assign 方法,但这次是用数组的元素来重新分配链表的内容。通过计算数组的大小,将整个 array 的内容赋值给链表 L。执行这个操作后,链表的内容变为 {10, 20, 30, 40, 50}

list 的 remove、sort、unique、reverse 操作探究

 
/*list的remove、sort、unique、reverse操作探究*/
#if 1
#include <list>
#include <vector>
#include <iostream>
#include <algorithm>
using namespace std;
void TestList5() {list<int> L{ 1, 2, 3, 4, 5, 1, 2, 3, 4, 5, 1, 1, 1};L.remove(1);L.sort();L.unique();L.reverse();}int main() {TestList5();}
#endif

初始链表的创建

list<int> L{ 1, 2, 3, 4, 5, 1, 2, 3, 4, 5, 1, 1, 1};

首先,通过初始化列表创建了一个包含重复元素的 list

删除特定元素

L.remove(1);

remove 方法从链表中删除所有值为 1 的元素。执行这个操作后,链表中所有的 1 被移除,链表变为 {2, 3, 4, 5, 2, 3, 4, 5}

对链表进行排序

L.sort();

sort 方法对链表中的元素进行排序。std::list 提供了自己的 sort 成员函数,因为标准算法库中的 std::sort 需要随机访问迭代器,而 list 只提供双向迭代器。排序后,链表变为 {2, 2, 3, 3, 4, 4, 5, 5}

移除连续重复的元素

L.unique();

unique 方法移除链表中连续重复的元素,只保留了每组重复元素中的第一个元素。在排序后的链表中应用 unique,会移除所有的连续重复项,链表变为 {2, 3, 4, 5}

反转链表

L.reverse();

reverse 方法将链表中的元素反向排列。执行这个操作后,链表中的元素顺序被反转,即 {5, 4, 3, 2}

list 的 remove_if 操作探究

 
/*list的remove_if操作探究*/
#if 1
#include <list>
#include <vector>
#include <iostream>
#include <algorithm>
using namespace std;bool IsEven(int data) {// 5的二进制:0000 0101//          0000 0001// return 0 == (data & 0x01);return 0 == data % 2;}void TestList6() {list<int> L{ 1, 2, 3, 4, 5 };L.push_back(6);L.push_back(7);L.push_back(8);L.push_back(9);L.remove_if(IsEven);}int main() {TestList6();}
#endif

remove_if 方法允许用户指定一个谓词(一个返回布尔值的函数或函数对象),根据这个谓词来决定哪些元素应该被移除。

定义判定函数

bool IsEven(int data) {

return 0 == data % 2;

}

这个函数 IsEven 检查给定的整数是否为偶数。如果是偶数,返回 true;否则返回 false

初始化 std::list 并添加元素

list<int> L{ 1, 2, 3, 4, 5 };

L.push_back(6);

L.push_back(7);

L.push_back(8);

L.push_back(9);

首先,通过初始化列表创建了一个包含元素 {1, 2, 3, 4, 5}list,然后依次添加了元素 6789 到链表的末尾。

使用 remove_if 根据条件移除元素

L.remove_if(IsEven);

remove_if 方法接受一个谓词函数 IsEven 作为参数,并移除 L 中所有使得 IsEven 返回 true 的元素。在这个例子中,它会移除链表中所有的偶数。

执行 remove_if 之后,原始链表 {1, 2, 3, 4, 5, 6, 7, 8, 9} 中的偶数元素被移除,留下了 {1, 3, 5, 7, 9}

list 的迭代器失效探究

 
/*list的迭代器失效探究*/
#if 1
#include <list>
#include <vector>
#include <iostream>
#include <algorithm>
using namespace std;void TestList7() {list<int> L{ 1, 2, 3, 4, 5 };L.push_back(6);L.push_back(7);L.push_back(8);L.push_back(9);//1auto it = L.begin();L.pop_front();while (it != L.end()){cout << *it << " ";++it;}
//2L.resize(0);while (it != L.end()){cout << *it << " ";++it;}
//3L.assign(10, 5);list<int> L1{ 10, 20, 30, 40, 50 };L = L1;while (it != L.end()){cout << *it << " ";++it;}
//4while (it != L.end()) {// L.erase(it);// ++it;it = L.erase(it);}}int main() {TestList7();}
#endif

初始化列表和添加元素

list<int> L{ 1, 2, 3, 4, 5 };

L.push_back(6);

L.push_back(7);

L.push_back(8);

L.push_back(9);

这段代码初始化了一个包含 {1, 2, 3, 4, 5, 6, 7, 8, 9}list

删除链表的第一个元素

auto it = L.begin();

L.pop_front();

it 初始化为指向链表的第一个元素。随后,pop_front() 删除了链表的第一个元素。由于 it 此时指向的元素被删除,it 的状态变得未定义,导致迭代器失效。正确的做法是在删除操作之后重新获取 begin() 的迭代器。

清空链表

L.resize(0);

这段代码将链表的大小调整为 0,相当于清空了链表。此时,除了 end() 迭代器之外,任何其他迭代器都变得无效,包括之前的 it

stl_list_h 中"operator ="底层代码

 
/*operator = 重载*/
template <class T, class Alloc>
list<T, Alloc>& list<T, Alloc>::operator=(const list<T, Alloc>& x) {if (this != &x) {iterator first1 = begin();iterator last1 = end();const_iterator first2 = x.begin();const_iterator last2 = x.end();while (first1 != last1 && first2 != last2) *first1++ = *first2++;if (first2 == last2)erase(first1, last1);elseinsert(last1, first2, last2);}return *this;}

template <class T, class Alloclist<T, Alloc>& list<T, Alloc>::operator=(const list<T, Alloc>& x) {

这一行声明了一个模板函数,这个函数是list类的成员函数,用于重载赋值运算符=T是列表中存储元素的类型,而Alloc是分配器类型,用于控制元素的内存分配。该函数接收一个常量引用x作为参数,这个参数是另一个list对象,表示要从中复制数据。函数返回对当前对象的引用,允许链式赋值。

if (this != &x) {

这一行检查自赋值的情况。如果被赋值的对象(*this)和赋值来源对象(x)是同一个对象,则不执行任何操作。这是为了防止自我复制时可能发生的资源泄露或不必要的操作。

iterator first1 = begin(); iterator last1 = end(); const_iterator first2 = x.begin(); const_iterator last2 = x.end();

这四行代码初始化四个迭代器。first1last1分别是当前list对象的起始和结束位置的迭代器。first2last2是参数x(即要复制的list对象)的起始和结束位置的常量迭代器。

while (first1 != last1 && first2 != last2) *first1++ = *first2++;

这行代码在两个列表都没有遍历完之前,逐个元素地从x复制元素到当前对象。*first1++ = *first2++这个表达式复制元素值,并将两个迭代器分别向前移动到下一个元素。

if (first2 == last2)erase(first1, last1);elseinsert(last1, first2, last2);

在完成上述循环后,会有两种情况:

如果x的元素已经复制完,但当前对象中还有剩余元素,这些剩余元素需要被删除。这通过调用erase(first1, last1)实现,它删除从first1last1(不包括last1)范围内的所有元素。

如果当前对象的元素已经被完全覆盖,但x中还有未复制的元素,这些元素需要被插入到当前对象的末尾。这通过调用insert(last1, first2, last2)实现,它从first2last2的范围内插入元素到last1位置之前。

return *this;

最后,函数返回当前对象的引用,使得可以进行链式赋值操作(例如,a = b = c)。

重新分配链表内容

L.assign(10, 5);

list<int> L1{ 10, 20, 30, 40, 50 };

L = L1;

assign底层实现和operator=大致是相同的。根据迭代器指向的位置元素是否被销毁来判断迭代器是否失效。示例代码迭代器没有发生失效。

删除操作

while (it != L.end()) {

it = L.erase(it);

}

这种模式是正确的方式来删除链表中的元素,因为 erase 返回指向被删除元素下一个元素的迭代器。

结尾

最后,感谢您阅读我的文章,希望这些内容能够对您有所启发和帮助。如果您有任何问题或想要分享您的观点,请随时在评论区留言。

同时,不要忘记订阅我的博客以获取更多有趣的内容。在未来的文章中,我将继续探讨这个话题的不同方面,为您呈现更多深度和见解。

谢谢您的支持,期待与您在下一篇文章中再次相遇!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://xiahunao.cn/news/2778052.html

如若内容造成侵权/违法违规/事实不符,请联系瞎胡闹网进行投诉反馈,一经查实,立即删除!

相关文章

使用Arduino UNO和蓝牙模块制作智能小车

目录 概述 1 硬件结构 1.1 硬件组成 1.2 蓝牙模块介绍 1.3 控制板IO引脚定义 2 机械结构 3 固件设计 4 App设计 5 参考文献 概述 本文主要介绍使用Arduino UNO作为主板&#xff0c;用于控制电机和接收蓝牙模块数据。蓝牙模块用于从手机App上接收控制信号&#xff0c;使…

(每日持续更新)信息系统项目管理(第四版)(高级项目管理)考试重点整理第10章 项目进度管理(四)

博主2023年11月通过了信息系统项目管理的考试&#xff0c;考试过程中发现考试的内容全部是教材中的内容&#xff0c;非常符合我学习的思路&#xff0c;因此博主想通过该平台把自己学习过程中的经验和教材博主认为重要的知识点分享给大家&#xff0c;希望更多的人能够通过考试&a…

巴尔加瓦算法图解:算法运用(上)

目录 树反向索引傅立叶变换 并行算法MapReduce函数 树 如果能将用户名插入到数组的正确位置就好了&#xff0c;这样就无需在插入后再排序。为此&#xff0c;有人设计了一种名为二叉查找树(binary search tree)的数据结构。 每个node的children 都不大于两个。对于其中的每个…

python_蓝桥杯刷题记录_笔记_全AC代码_入门4

题单目录 1.P1914 小书童——凯撒密码 2.P1028 [NOIP2001 普及组] 数的计算 3.P1036 [NOIP2002 普及组] 选数 4.P1149 [NOIP2008 提高组] 火柴棒等式 5.P1217 [USACO1.5] 回文质数 Prime Palindromes 6.P1478 陶陶摘苹果&#xff08;升级版&#xff09; 7.P1618 三连击&…

软件价值11-简单计算器

用python的tkinter做的简单计算器 代码&#xff1a; import tkinter as tkdef button_click(item):global expressionexpression expression str(item)input_text.set(expression)def button_clear():global expressionexpression ""input_text.set(""…

51单片机编程应用(C语言):串口通信

目录 通信的基本概念和种类 1.1串行通信与并行通信 ​编辑 1.2同步通信与异步通信 1.3单工&#xff0c;半双工&#xff0c;全双工 1.4通信速率 二、波特率和比特率的关系 串口通信简介&#xff1a; 1.接口标准 RS-232 2、D型9针接口定义 3.通信协议&#xff1a; …

嵌入式系统的前景:未来智能汽车

&#xff08;本文为简单介绍&#xff0c;个人的观点仅供参考&#xff09; 智能汽车时代已经来临!未来十年,我们的汽车将变得越来越智能化。各大汽车公司在研发自动驾驶技术,目标是实现真正的无人驾驶。要实现这一目标,嵌入式系统将发挥关键作用。 简单来说,嵌入式系统就是在汽…

【Make编译控制 01】程序编译与执行

目录 一、编译原理概述 二、编译过程分析 三、编译动静态库 四、执行过程分析 一、编译原理概述 make&#xff1a; 一个GCC工具程序&#xff0c;它会读 makefile 脚本来确定程序中的哪个部分需要编译和连接&#xff0c;然后发布必要的命令。它读出的脚本&#xff08;叫做 …

AcWing 1240 完全二叉树的权值(双指针)

[题目概述] 给定一棵包含 N 个节点的完全二叉树&#xff0c;树上每个节点都有一个权值&#xff0c;按从上到下、从左到右的顺序依次是 A 1 , A 2 , ⋅ ⋅ ⋅ A N A_1,A_2,⋅⋅⋅A_N A1​,A2​,⋅⋅⋅AN​&#xff0c;如下图所示&#xff1a; 现在小明要把相同深度的节点的权值…

算法竞赛进阶指南——搜索

树与图的遍历 可达性统计 #include<iostream> #include<cstring> #include<bitset> using namespace std; const int N 3e4 10; int h[N], e[N], ne[N], idx; //链式向前星 int q[N], hh, tt -1; //队列 int r[N], a[N]; //r是入度&#xff0c;a是拓扑序…

VitePress-13- 配置-title的作用详解

作用描述 1、title 是当前站点的标题&#xff1b;2、默认值是 &#xff1a;VitePress&#xff1b;3、当使用默认主题时&#xff0c;会直接展示在 页面的【导航条】中&#xff1b;4、一个特殊的作用 &#xff1a; 会作为单个页面的默认标题后缀&#xff01;除非又指定了【title…

一文彻底搞懂Kafka如何保证消息不丢失

文章目录 1. kafka 架构2. producer端是如何保证数据不丢失的2.1 同步发送2.2 异步发送2.3 批量发送 3. consumer端是如何保证数据不丢失的3.1 手动提交3.2 幂等性消费 4. broker端是如何保证数据不丢失的4.1 副本机制4.2 ISR机制4.3 刷盘机制 1. kafka 架构 Producer&#xff…

【从Python基础到深度学习】6. IPython使用PyCharm代码调试与使用PEP

一、IPython交互式shell Python的解释器如今有多个语言的实现&#xff0c;包括: CPython ——官方版本的c语言实现 ython ——可以运行在Java平台 IronPython ——可以运行在.NET和Mono平台PyPy —— Python实现的&#xff0c;支持JIT即时编译 1.PyCharm中 2.Ubuntu终端中 s…

一、基础算法之排序、二分、高精度、前缀和与差分、双指针算法、位运算、离散化、区间合并内容。

1.快速排序 算法思想&#xff1a;选择基准元素&#xff0c;比基准元素小的放左边&#xff0c;比基准元素大的放右边。每趟至少一个元素排好。 每一趟实现步骤&#xff1a; low>high&#xff0c;返回&#xff0c;排序完成选取基准元素xa[low],ilow,jhigh当i<j时&#x…

【人工智能】文本嵌入:向量存储与数据查询的智慧交织(12)

在当今信息激增的时代&#xff0c;将中文存储到向量数据库&#xff08;如Redis等&#xff09;并实现向量检索&#xff0c;正成为解决日常应用中文信息处理难题的关键利器。这项技术不仅赋予计算机对中文语义的理解能力&#xff0c;更让我们能够以更智能、高效的方式处理和检索中…

机器学习2---逻辑回归(基础准备)

逻辑回归是基于线性回归是直线分的也可以做多分类 ## 数学基础 import numpy as np np.pi # 三角函数 np.sin() np.cos() np.tan() # 指数 y3**x # 对数 np.log10(10) np.log2(2) np.e np.log(np.e) #ln(e)# 对数运算 # log(AB) log(A) logB np.log(3*4)np.log(3)np.log(4) #…

【MySQL】-12 MySQL索引(上篇MySQL索引类型前置-2-高性能的索引策略)

MySQL索引-高性能的索引策略 3 高性能的索引策略3.1 独立的列3.2 前缀索引和索引选择性3.3 多列索引3.4 选择合适的索引列顺序3.5 聚簇索引(Clustered Indexes)3.5.1 InnoDB和MyISAM的数据布局的比较3.5.2 按primary key的顺序插入行(InnoDB) 3.6 覆盖索引(Covering Indexes)3.…

【深度学习】: 脑部MRI图像分割

清华大学驭风计划课程链接 学堂在线 - 精品在线课程学习平台 (xuetangx.com) 代码和报告均为本人自己实现&#xff08;实验满分&#xff09;&#xff0c;只展示主要任务实验结果&#xff0c;如果需要详细的实验报告或者代码可以私聊博主&#xff0c;接实验技术指导1对1 有任…

QT入门-信号与槽

1.QT基本框架 #include "myWindow.h"#include <QApplication>int main(int argc, char *argv[]) {QApplication a(argc, argv);myWindow w;w.show();return a.exec(); } QApplicata&#xff1a;应用程序对象&#xff0c;必须有且只能有一个 Qwidget&#xff1…

Python入门:常用模块—os模块及sys模块

os模块 sys模块 import sys print(sys.argv) # 命令参数list&#xff0c;第一个元素是程序本身路径 print(sys.exit()) # 退出程序&#xff0c;正常退出是exit(0) print(sys.version) # 获取python解释程序的版本信息 print(sys.maxint()) # 最大…