嵌入式笔试刷题(第六天)

11. 怎样检测链表是否存在循环(只读内存,内存有限)

解法:快慢指针法(Floyd 判圈法)

struct Node {
    int val;
    struct Node *next;
};

int has_cycle(struct Node* head) {
    struct Node *slow = head, *fast = head;
    while (fast && fast->next) {
        slow = slow->next;
        fast = fast->next->next;
        if (slow == fast)
            return 1; // 存在环
    }
    return 0; // 无环
}

**优点:**不需要修改链表,不使用额外空间,适用于只读内存和内存受限情况。

12. C++ 中 structclass 的区别

成员权限默认

public

private

继承权限默认

public

private

其他特性支持

支持构造/析构/继承

支持构造/析构/继承

总结:structclass 本质相同,仅默认访问权限不同。

13. C++ 中 mallocnew 的区别

属于哪种语言

C语言

C++语言

是否调用构造函数

是否类型安全

否,需强制转换

是否能重载

可以

报错方式

返回 NULL

抛出异常(bad_alloc)

14. 什么是“引用”?声明和使用“引用”要注意哪些问题?

引用(Reference):是变量的别名,必须初始化,不能重新绑定。

int a = 10;
int &ref = a; // ref 是 a 的引用

注意事项:

  • 引用必须初始化;
  • 引用不能为 NULL;
  • 不能重新引用另一个变量;
  • 可用于函数参数/返回值优化性能。

15. 什么时候使用“常引用”?

常引用:const Type&,常用于:

  • 避免复制大对象(如 std::stringstd::vector);
  • 防止函数修改参数;
  • 函数返回值时引用内部数据。

示例:

void printString

剩余60%内容,订阅专栏后可继续查看/也可单篇购买

嵌入式笔试专栏 文章被收录于专栏

本专栏系统整理了嵌入式方向笔试中常见的知识点和高频考题,涵盖基础理论、常用算法、C语言陷阱、操作系统原理、驱动开发、常见外设通信协议(如 I2C/SPI/UART)、RTOS、Linux 内核、以及实用电路知识等内容。

全部评论
点赞 回复 分享
发布于 04-25 21:39 山西
😄😄😄😄
点赞 回复 分享
发布于 04-25 16:23 上海
快慢指针很妙
点赞 回复 分享
发布于 04-15 15:10 黑龙江

相关推荐

06-13 10:15
门头沟学院 Java
想去夏威夷的大西瓜在...:我也是27届,但是我现在研一下了啥项目都没有呀咋办,哎,简历不知道咋写
点赞 评论 收藏
分享
07-11 22:27
中南大学 Java
程序员牛肉:学历的话没问题。但是没问题的也就只有学历了。 其实你的整体架构是正确的,博客接着干。但是项目有点过于简单了。从后端的角度上讲,你这也就是刚入门的水平,所以肯定约面试够呛。 如果你要应聘后端岗位,那你第一个项目竟然是仿写操作系统。这个你要面试官咋问你。你一定要记住一点,你简历上写的所有的东西,都是为了证明你有能力胜任当前的岗位,而不是为了证明你自己会什么。 如果你只是浅浅的做几个项目,描述也都是烂大街。技术点也都是各种混水类的配置类需求,那你就不要幻想自己能走多远。一定要保持思考,保持学习。
点赞 评论 收藏
分享
评论
4
8
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务