【笔试】02

TCP

TCP(传输控制协议)是一种面向连接的可靠的基于字节流的传输层通信协议

它能够提供以下服务:

  • 可靠传输
    通过序列号、确认应答、重传机制等确保数据完整、准确地从发送端传输到接收端。
    三次握手:
    在这里插入图片描述
  • 点对点
  • 全双工
  • 面向字节流
  • 流量控制:通过滑动窗口机制,接收端可以控制发送端的发送速率,防止接收端来不及处理导致数据丢失。
  • 拥塞控制:当网络出现拥堵时,TCP能够减少其数据传输速率,避免造成更严重的网络拥塞。
  • 数据顺序控制:保证数据按照发送顺序到达接收端。
  • 对比:

在这里插入图片描述

不能提供的服务:

  • 时延和带宽保证
  • 多播和广播:TCP是基于点对点的通信模式,不支持多播(一点对多点)和广播(一点对全点)通信。

HTTP

  • 使用TCP传输
    TCP是一个传输协议,而HTTP全称是超文本传输协议,是在传输时使用TCP协议,HTTP是在应用层进行握手,即服务器上的运行的进程之间的通信
  • HTTP不保留状态,或者说无状态stateless
  • 消息格式
    • 发送:方法(GET POST)+URL+协议
    • 相应:协议+状态码+状态词
  • 响应状态码:
    • 404 Not Found: 表示客户端能够与服务器通信,但服务器找不到请求的资源。
    • 200 OK:请求成功,服务器提供了请求的网页
    • 5XX - 服务器错误

字符数组初始化方法

  • 直接赋值
    编译器会自动计算数组str的大小,包括字符串的结尾标识符\0。
char str[] = "Hello, World!";
  • 指定大小赋值
    数组的大小必须足够大,以存储所有字符和末尾的\0。
char str[14] = "Hello, World!";
  • 逐字符填充
    逐字符初始化时,必须包括字符串的结束符\0。
    如果你指定的大小大于实际初始化的字符数(包括必需的终止符\0),剩余的部分将自动用\0填充。
char str[] = {'H', 'e', 'l', 'l', 'o', ',', ' ', 'W', 'o', 'r', 'l', 'd', '!', '\0'};
  • 二维数组也要注意/0
char str[4][6] = {"hello", "world"};

unsigned int 范围

int 在大多数系统上占用 4 个字节(32 位),其取值范围是从 -2147483648 到 2147483647
unsigned int 在大多数系统上占用 4 个字节(32 位),其取值范围为 0 到 4294967295。

冒泡排序

冒泡排序的基本思想是,重复地遍历待排序序列,每次比较相邻的两个元素,如果它们的顺序错误,则交换它们。通过每次遍历,将最大的元素“冒泡”到最后

def bubble_sort(arr):n = len(arr)for i in range(n):for j in range(0, n-i-1):if arr[j] > arr[j+1]:arr[j], arr[j+1] = arr[j+1], arr[j]return arr

选择排序

选择排序的基本思想是,每次从待排序的元素中选择最小的元素,放置到已排序序列的末尾。

def selection_sort(arr):n = len(arr)for i in range(n):min_index = ifor j in range(i+1, n):if arr[j] < arr[min_index]:min_index = jarr[i], arr[min_index] = arr[min_index], arr[i]return arr

补码

补码是一种用于表示有符号整数的编码方式,常用于计算机系统中。在补码表示法中,正整数的二进制表示与无符号整数相同,而负整数的表示稍有不同。

具体来说,对于一个 n 位的补码表示:

对于正整数,其补码与其原码(即二进制表示)相同。
对于负整数,先将其绝对值表示成二进制形式,然后取反(每一位取反),最后加 1

在一个字节(8bit)的补码中,负数的表示范围是 -128 到 -1,而正数的表示范围是 0 到 127。

参数传递和内存分配

分析运行下面的Test函数会有什么样的结果,为什么?

void GetMemory1(char*p)
{
p = (char*)malloc(100);
}
void Testl(void)
{
char*str =NULL;
GetMemory1(str);
strcpy(str,"hello world");
printf(str);
}

GetMemory() 函数中的指针 p 是按值传递的,而不是按引用传递。在 GetMemory() 函数内部分配了内存,并将其地址存储在 p 中,但这个地址只是 GetMemory() 函数内部的局部变量,它并不会改变 Test() 函数中指针 str 的值。因此,Test() 函数中的 str 指针仍然是 NULL,没有指向任何有效的内存位置。
未定义行为导致程序崩溃,因为试图写入未分配的内存地址。

char *GetMemory2(void)
{
char p[] = "helloworld";
return p;
}
void Test2(void)
{
char *str =NULL;
str= GetMemory2();
printf(str);
}

输出乱码。

GetMemory() 函数中的局部数组 p 是在栈上分配的,它的生命周期仅限于 GetMemory() 函数的执行过程。当 GetMemory() 函数返回时,p 的内存将被释放,但 Test() 函数中的 str 指针仍然指向已释放的内存地址,这会导致未定义行为,可能会输出垃圾值,程序崩溃或其他意外行为。

void GetMemory(char** p, int num)
{*p = (char*)malloc(num);
}
void Test(void)
{char* str = NULL;GetMemory(&str, 100);strcpy(str, "hello");printf(str);
}

正确打印了hello。利用二级指针做函数形参,成功把str变成分配的大小为100字节连续空间的的起始地址。但是没有用free进行内存释放,造成内存泄漏。

void Test(void)
{char* str = (char*)malloc(100);strcpy(str, "hello");free(str);if (str != NULL){strcpy(str, "world");printf(str);}
}

虽然调用了 free(str) 释放了内存,但并没有将 str 指针置为 NULL。因此,在 if (str != NULL) 中,虽然 str 已经指向了一片已经释放的内存,但由于 str 本身并不是 NULL,所以条件成立,进入了 if 分支。所以正常进行strcpy(str, “world”);,最后打印world。对已经释放的内存进行操作,也可能导致未定义行为。

函数的继承派生、虚函数

这段代码的输出结果是什么

class Ca
{
public:Ca() {strcpy(m_info,"fa");printf("Ca”);}virtual void f() {printf(m info);}void f1(){printf("fa1”);}void f2(int i=3){ this->f();printf("%d”,i);}char m info[10];
};
class Cb:public Ca
{
public:Cb (){printf("cb”);}void f(){printf("fb”);}void f1(){printf("fb1”);}void f2(int i=5){ this->f();printf("%d”,i);}
};
int main()
{Ca* p=NULL;Ca a;Cb b;p = &a;p->f();p->f1();p->f2();p = &b;p->f();p->f1();p->f2();
}

**通过基类指针只能访问派生类的成员变量,但是不能访问派生类的成员函数。**为了消除这种尴尬,让基类指针能够访问派生类的成员函数,C++ 增加了虚函数(Virtual Function)。有了虚函数,基类指针指向基类对象时就使用基类的成员(包括成员函数和成员变量),指向派生类对象时就使用派生类的成员。换句话说,基类指针可以按照基类的方式来做事,也可以按照派生类的方式来做事,它有多种形态,或者说有多种表现方式,我们将这种现象称为多态(Polymorphism)。

Ca
Ca
Cb
fa
fa1
fa3
fb
fa1
fb3

模拟题

两个字符串 start 和 target,长度均为n。每个字符串 仅 由字符’L’、‘R’ 和’_‘组成,其中:字符"L’ 和’R’ 表示片段,其中片段"L’只有在其左侧直接存在一个 空位 时才能向 左 移动,而片段’R’ 只有在其右侧直接存在一个 空位 时才能向 右 移动。字符’'表示可以被 任意 ‘L’或’R’ 片段占据的空位。如果在移动字符串 start 中的片段任意次之后可以得到字符串 target ,返回 true ;否则,返回 false 。
示例 1:
输入:start=“L___R___R”,target="L______RR"输出:true

示例 2:
输入:start=“R_L _”,target=" __LR"
输出:false解释:字符串 start 中的’R’ 片段可以向右移动一步得到"RL"但是,在这一步之后,不存在可以移动的片段,所以无法从字符串 start 得到 target 。
示例 3:输入:start="R",target="R"输出:false解释:字符串 start 中的片段只能向右移动,所以无法从字符串 start 得到 target 。
实现函数
bool canChange(char* start, char* target),并说明思路

class Solution {
public:bool canChange(string start, string target) {if(start.size()!=target.size())return false;vector<pair<char,int>>s,t;for(int i=0;i<start.size();i++){if(start[i]!='_'){s.push_back(make_pair(start[i],i));}if(target[i]!='_'){t.push_back(make_pair(target[i],i));}}if(s.size()!=t.size())return false;for(int i=0;i<s.size();i++){if(s[i].first=='L' && s[i].second<t[i].second)return false;else if(s[i].first=='R' && s[i].second>t[i].second)return false;else if(s[i].first!=t[i].first)return false;}return true;}
};

将start和target数组里面的非’_'元素全存到vector<pair<char,int>>容器中,然后比较这两个容器,如果相同位置内容不同,则返回false;如果start代表的容器的’L’的下标位置小于target的位置,由于L不能右移,故返回false;同理start的R的位置大于target的R的位置则返回false;其他情况都是返回true。

链表题

leetcode 24 两两交换链表中的节点
https://leetcode.cn/problems/swap-nodes-in-pairs/description/?envType=study-plan-v2&envId=top-100-liked

/*** Definition for singly-linked list.* struct ListNode {*     int val;*     ListNode *next;*     ListNode() : val(0), next(nullptr) {}*     ListNode(int x) : val(x), next(nullptr) {}*     ListNode(int x, ListNode *next) : val(x), next(next) {}* };*/
class Solution {
public:ListNode* swapPairs(ListNode* head) {ListNode* dummy=new ListNode(0);dummy->next=head;ListNode* cur=dummy;ListNode* pre=dummy;while(cur->next!=NULL && cur->next->next!=NULL){pre=cur;cur=cur->next;ListNode* tmp=cur->next;cur->next=cur->next->next;tmp->next=cur;pre->next=tmp;   }ListNode* res=dummy->next;delete dummy;return res;}
};

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

1260. 二维网格迁移

1260. 二维网格迁移 原题链接&#xff1a;完成情况&#xff1a;解题思路&#xff1a;参考代码&#xff1a;错误经验吸取 原题链接&#xff1a; 1260. 二维网格迁移 https://leetcode.cn/problems/shift-2d-grid/description/ 完成情况&#xff1a; 解题思路&#xff1a; 这…

使用稳压管和三极管射极输出器电路驱动PMOS

当电源电压大于PMOS 管的最大栅源电源时&#xff0c;不能直接把栅极拉到地&#xff0c;需要一点特殊的电路来限制栅极驱动电压。有的地方是用电阻分压器做的&#xff0c;比如这种&#xff1a; NPN 三极管导通时&#xff0c;MOS 管栅极电压是两个电阻中间的电压。这种设计最大的…

106.从中序与后序遍历构造二叉树

给定两个整数数组 inorder 和 postorder &#xff0c;其中 inorder 是二叉树的中序遍历&#xff0c; postorder 是同一棵树的后序遍历&#xff0c;请你构造并返回这颗 二叉树 。 思路&#xff1a; 中序遍历数组中&#xff0c;找到一个根节点&#xff0c;那么其前为其左子树&a…

大模型用到的位置编码汇总(面试)

不同于RNN、CNN等模型&#xff0c;对于Transformer模型来说&#xff0c;位置编码的加入是必不可少的&#xff0c;因为纯粹的Attention模块是无法捕捉输入顺序的&#xff0c;即无法区分不同位置的Token。为此我们大体有两个选择&#xff1a;想办法将位置信息融入到输入中&#x…

Office 365卡顿怎么办?SD-WAN可以解决

随着数字化浪潮的推进&#xff0c;Office 365等云办公应用已成为企业日常运营不可或缺的工具。然而&#xff0c;许多企业在使用Office 365时遭遇了网络卡顿的难题&#xff0c;给工作人员带来诸多不便。随着SD-WAN技术的成熟和普及&#xff0c;这一难题得到了有效的解决。 Offic…

四足机器人应用篇之solidwork导出URDF

欢迎关注微信公众号 “四足机器人研习社”&#xff0c;本公众号的文章和资料和四足机器人相关&#xff0c;包括行业的经典教材、行业资料手册&#xff0c;同时会涉及到职业知识学习及思考、行业发展、学习方法等一些方面的文章。 |1.URDF介绍 一个URDF pakage示例 urdf是ROS用于…

ABAP MESSAGE 常用的类型

类型文本描述A终止处理终止&#xff0c;用户必须重启事务X退出与消息类型A 类似&#xff0c;但带有程序崩溃 MESSAGE_TYPE_XE错误处理受到干扰&#xff0c;用户必须修正输入条目,左下角提示!W警告处理受到干扰&#xff0c;用户可以修正输入条目,左下角提示!I信息处理受到干扰&a…

数据库讲解---(数据更新、视图、数据控制)【MySQL版本】

目录 前言 一.数据更新 1.1插入数据 1.1.1插入单个元组 1.1.2将一个新学生记录(学号:091530,姓名:夏雨,性别:男,籍:海南,出生年份:1999,学院:计算机)插入到学生表中 1.1.3插入子查询结果 1.1.4有一个表“DEPT”(SDEPT CHAR(20),AVG_AGE SMALLINT)表示每个学院的学生的平…

网络安全-自学笔记

一、自学网络安全学习的误区和陷阱 1.不要试图先成为一名程序员&#xff08;以编程为基础的学习&#xff09;再开始学习 我在之前的回答中&#xff0c;我都一再强调不要以编程为基础再开始学习网络安全&#xff0c;一般来说&#xff0c;学习编程不但学习周期长&#xff0c;而…

【力扣TOP100热题图解】T1.两数之和

题目链接点这里—— 力扣&#xff08;LeetCode&#xff09;​​​​​​ 法一&#xff1a;暴力枚举 最容易想到的方法是枚举数组中的每一个数 x&#xff0c;寻找数组中是否存在 target - x。 当我们使用遍历整个数组的方式寻找 target - x 时&#xff0c;需要注意到每一个位…

【Linux】磁盘管理和文件系统

目录 一、硬盘 1.硬盘结构 2.结构类型 二、MBR与磁盘分区 1.MBR主引导记录 2.磁盘分区结构 三、文件系统类型 四、linux系统添加并使用新硬盘的步骤 1.添加新的硬盘 2.刷新识别 3.进行分区 4.格式化&#xff0c;创建文件系统 5.挂载使用 一、硬盘 1.硬盘结构…

SpringBoot整合消息中间件(ActiveMQ,RabbitMQ,RocketMQ,Kafka)

消息中间件 消息消息队列JMS AMQPMQTTKafka Spring整合消息队列模拟消息队列的工作流程Spring整合ActiveMQSpring整合RabbitMQ直连交换机模式主题交换机模式 Spring整合RocketMQSpring整合kafka 消息 消息的发送方&#xff1a;生产者 消息的接收方&#xff1a;消费者 同步消息…

基于SSM项目高校在线请假与审批系统

采用技术 基于SpringBoot框架实现的web的智慧社区系统的设计与实现~ 开发语言&#xff1a;Java 数据库&#xff1a;MySQL 技术&#xff1a;SpringMVCMyBatis 工具&#xff1a;IDEA/Ecilpse、Navicat、Maven 简介 本系统实现了管理员&#xff0c;教师&#xff0c;学生三个模…

OSPF动态路由实验(华为)

思科设备参考&#xff1a;OSPF动态路由实验&#xff08;思科&#xff09; 一&#xff0c;技术简介 OSPF&#xff08;Open Shortest Path First&#xff09;是一种内部网关协议&#xff0c;主要用于在单一自治系统内决策路由。它是一种基于链路状态的路由协议&#xff0c;通过…

Linux下SPI设备驱动实验:实现SPI发送/接收数据的函数

一. 简介 前面文章介绍了SPI设备数据收发处理流程&#xff0c;后面几篇文章实现了SPI设备驱动框架&#xff0c;加入了字符设备驱动框架代码。文章如下&#xff1a; SPI 设备驱动编写流程&#xff1a;SPI 设备数据收发处理流程中涉及的结构体与函数-CSDN博客 SPI 设备驱动编写…

【洛谷 P8802】[蓝桥杯 2022 国 B] 出差 题解(带权无向图+单源最短路+Dijkstra算法+链式前向星+最小堆)

[蓝桥杯 2022 国 B] 出差 题目描述 A \mathrm{A} A 国有 N N N 个城市&#xff0c;编号为 1 … N 1 \ldots N 1…N 小明是编号为 1 1 1 的城市中一家公司的员工&#xff0c;今天突然接到了上级通知需要去编号为 N N N 的城市出差。 由于疫情原因&#xff0c;很多直达的交…

MXXE利用XXE漏洞快速获取服务器敏感文件工具

https://github.com/MartinxMax/MXXE 关于 MXXEV1.2升级版,快速获取服务器敏感文件 获取Windows服务器敏感文件 把数据包复制到payload.txt进行自动注入 $ python3 MXXE.py -lh 10.10.16.5 -user Daniel -server windows 幸运的是我们找到了服务器的私匙 获取Linux服务器敏感…

LeetCode-706. 设计哈希映射【设计 数组 哈希表 链表 哈希函数】

LeetCode-706. 设计哈希映射【设计 数组 哈希表 链表 哈希函数】 题目描述&#xff1a;解题思路一&#xff1a;超大数组解题思路二&#xff1a;拉链法解题思路三&#xff1a; 题目描述&#xff1a; 不使用任何内建的哈希表库设计一个哈希映射&#xff08;HashMap&#xff09;。…

数字孪生与企业

数字孪生技术&#xff0c;简而言之&#xff0c;就是创造一个物理实体的数字双胞胎&#xff0c;在虚拟世界中精确模拟现实世界的行为、过程和系统。这种技术的核心在于&#xff0c;它允许我们在数字环境中实时地监控、分析和优化其物理对应物的性能和效率。数字孪生的应用场景极…

【深入理解】width 的默认值,2024年最新面试复盘

先自我介绍一下&#xff0c;小编浙江大学毕业&#xff0c;去过华为、字节跳动等大厂&#xff0c;目前阿里P7 深知大多数程序员&#xff0c;想要提升技能&#xff0c;往往是自己摸索成长&#xff0c;但自己不成体系的自学效果低效又漫长&#xff0c;而且极易碰到天花板技术停滞…