当前位置: 首页 > 面试经验 >

2024届 百度C++提前批一面

优质
小牛编辑
90浏览
2023-08-02

2024届 百度C++提前批一面

其实也没什么好写的,百度一面体验确实很好,面试官会进行一些提醒,交流非常愉快。

不过感觉我这个面试流程确实跟大部分人都不太一样,没有八股环节。

8月1日面试的,总结一下,面试大概1h,勉强分为三个部分

1、自我介绍

2、着重聊了一下硕士期间做的项目,我硕士在CAD实验室,做的也是图形学相关的工作,面试官对我用GPU或者多线程多进程进行并行加速比较感兴趣,大概聊了10min

3、(C++)手动实现一个自己的class string,要我实现一个char* s作为输入的构造函数,再实现一个append的拼接功能。最后是每次append都要申请新的空间并进行复制的话开销太大了,有没有什么优化方案,我举了几种方案,包括可以参考stl的方式,当空间不足时直接申请1.5倍原始大小的空间,并进行数据转移,面试官让我按这个思路实现了一下。

这部分前后花了接近50min吧,考核方式是我这边共享自己的屏幕,然后再自己的IDE上进行实现。

其实主要问题是,我用的是vs,在vs中strcpy、strncpy不能直接用,如何忽略这个错误我给忘了,建议用strcpy_s和strncpy_s,我索性自己用while自己造轮子了,不确定会不会减分……

面试结束一直觉得自己写的太丑陋了,基本都是C风格的代码,可能还是Mordern C++用的不够多不熟练。不过看了一下网上很多人给的答案,好像跟我风格也都差不多。

等等看有没有二面的机会

想了想,附一下自己代码。写的时候初衷是,先快速实现功能,再慢慢修改

#include <iostream>

class my_string
{
public:
	my_string(const char* s) 
	{
		length = 0;
		const char* s_head = s;
		while (*s != '\0')
		{
			s++;
			length++;
		}
		s = s_head;

		size = length;
		str = (char*)malloc(sizeof(char)*(size + 1));

		for(int i = 0; i < length; i++)
		{
			*(str + i) = *(s + i);
		}
		*(str + length) = '\0';
	}

	my_string& append(my_string s)
	{
		
		if (this->length + s.length >= this->size)
		{
			while(this->size <= this->length + s.length)
				this->size = this->size * 3 / 2;
		  
			char* old_str = str;
			str = (char*)malloc(sizeof(char) * (this->size + 1));
			for (size_t i = 0; i < this->length; i++)
			{
				*(this->str + i) = *(old_str + i);
			}
			free(old_str);
		}

		for (size_t i = 0; i <= s.length; i++)
		{
			*(this->str + this->length + i) = *(s.str + i);
		}
		this->length += s.length;
		return *this;
	}

private:
	char* str;
	size_t length;
	size_t size;
};

int main()
{
	my_string* my_str1 = new my_string("Hello ");
	my_string* my_str2 = new my_string("World");
	my_str1->append(*my_str2);
	return 0;
}

 类似资料: