面试题目搜集(5)

2023-11-17

本博客的《面试题目搜集系列不错》

(1)面试题目搜集1

(2)面试题目搜集2

(3)面试题目搜集3

(4)面试题目搜集4

(5)面试题目搜集5

(6)面试题目搜集6


1.反着打印链表(递归实现)

#include<iostream>
#include <cstdio>
using namespace std;

typedef int Elem;

struct ListNode{
	Elem nData;
	ListNode *pNext;
	ListNode(int data,ListNode *next=NULL):nData(data),pNext(next){}
};

void PrintReverseList(ListNode *root)
{
	if(!root)
		return;
	PrintReverseList(root->pNext);
	cout<<root->nData<<" ";
};
int main()
{	
	ListNode *list3 = new ListNode(3,NULL);
	ListNode *list2 = new ListNode(2,list3);
	ListNode *list1 = new ListNode(1,list2);
    ListNode *pHead = new ListNode (0,list1);

	PrintReverseList(pHead);
	system("pause");
	return 0;
}


2.求最大连续字符串 (如“ ads3s1456789DF3456ld345AA ”,结果为“456789”)

#include <iostream>
#include <string>
using namespace std;

typedef int StartIndex;
typedef int StrLenght;
typedef pair<StartIndex,StrLenght> Result;

Result FindContinuousSubStr(const string& str)
{
	int start = 0;
	int maxLen = 1;
	int length = 1;

	for(int i=1; i<str.size();++i){
		if(str[i] == str[i-1] + 1){
			++length;
		}
		else{
			if(length > maxLen){
				maxLen = length;
				start = i - length;
			}
			length = 1;
		}
	}

	return make_pair(start,maxLen);
}

int main()
{
	string str = "ads3s1456789DF3456ld345AA";
	Result ret = FindContinuousSubStr(str);

	for(int i=0; i<ret.second; ++i){
		cout<<str[ret.first+i];
	}

	system("pause");
	return 0;
}


3.编写CString类

class CString{
public:
	CString(const char *pStr = NULL){
		if(pStr == NULL){
			pData = new char;
			*pData = '\0';
		}
		else{
			pData = new char[strlen(pStr)+1];
			assert(pData != NULL);
			strcpy(pData,pStr);
		}
	}
	CString(const CString& other){
		pData = new char[strlen(other.pData)+1];
		assert(pData != NULL);
		strcpy(pData,other.pData);
	}
	CString& operator=(const CString& other){
		if(&other == this){
			CString strTemp(other);

			char *pTemp = strTemp.pData;
			strTemp.pData = pData;
			pData = pTemp;
		}
		return *this;
	}
	~CString(){
		if(!pData)
			delete[] pData;
	}
private:
	char *pData;
};


4.百度的一道笔试题目: 下面这段代码是把中英文混合字符串(汉字用两个字节表示,特点是第一个字节的最高位为1)中的大写字母转化为小写字母,请找出其中的bug,注意各种异常情况。 
for (char *piterator = szWord; *piterator != 0; piterator++) 

if (*piterator & 0x80 != 0) 

piterator++; 

else if (*piterator >= 'A' && *piterator <= 'Z') 

piterator += 32; 

上面有两个bug,答案更正如下:

#include <iostream>

using namespace std;

void Convert(char *szWord)
{
	for (char *piterator = szWord; *piterator != '\0'; piterator++) 
		if ((*piterator & 0x80) != 0) 
				piterator++;
		else if (*piterator >= 'A' && *piterator <= 'Z') 	
				*piterator += 32; 

	cout<<szWord<<endl;
}


int main()
{
	char str[] = "我是LSJ,请把我ZHUANHuan为小XIE";
	Convert(str);
	system("pause");
	return 0;
}

5.百度2012年实习得一道招聘题目。

        相信大家都使用过百度搜索框的suggestion功能(如下图所示)。百度搜索框中的suggestion提示功能如何实现的?请给出实现思路和主要的数据结构、算法。有什么优化思路可以使得时间和空间效率最高?
如下图所示:


答:统计搜索引擎查询日志,统计各个查询词出现的次数。然后统计查询串中可能出现的各个前缀子串,然后统计以各个前缀子串开头的查询串的频率。对各个子串,取以其作为前缀的前K个最高频查询串。再以各个子串为KEY,建立倒排索引(或trie树)。定期更新倒排索引(或trie树),即可依据查询频率给出一个比较合理的提示内容。当用户输入时,去倒排索引(或trie树)中进行匹配,然后取其出现频率最高的前K个。

注:应用字典树来求前缀和TOP K对热词进行统计排序,求前缀用trie树(o(nle),le表示字符串的平均长度)


6.析构函数不能抛出异常

(1)构造函数可以抛出异常。

(2)c++标准指明析构函数不能、也不应该抛出异常。

more effective c++关于第2点提出两点理由:

1)如果析构函数抛出异常,则异常点之后的程序不会执行,如果析构函数在异常点之后执行了某些必要的动作比如释放某些资源,则这些动作不会执行,会造成诸如资源泄漏的问题。

2)通常异常发生时,c++的机制会调用已经构造对象的析构函数来释放资源,此时若析构函数本身也抛出异常,则前一个异常尚未处理,又有新的异常,会造成程序崩溃的问题。

解决办法:

1)永远不要在析构函数抛出异常。

2)通常第一点有时候不能保证。可以采取如下的方法:

~ClassName()

{

  try{

      do_something();

  }

  catch(){  //这里可以什么都不做,只是保证catch块的程序抛出的异常不会被扔出析构函数之外。

   }

}




本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

面试题目搜集(5) 的相关文章

  • LeetCode64. 最小路径和

    题目大意 求出从网络左上角到右下角的一条代价最小的路径和 题目分析 使用动态规划 求出左上角到网络中每个点的代价最小路径和 假设当前要求的是point i j 点 那么它的值就应该是从左上角到它上面那个点point i 1 j 的路径和 与
  • 【技术应用】Qt Creator使用体会与小技巧

    Qt Creator是Qt官方的IDE 这个IDE为Qt编程人员提供了一个完整的开发环境 当然了 这个IDE是用Qt写的 也是免费的 这个IDE真正的编译部分使用了MinGW gcc compiler 也就是说 这个IDE主要的作用是协助开

随机推荐

  • 教务管理系统(免费源码获取)

    项目介绍 本系统使用springboot mybatis plus shiro lombok等技术 使用json传递数据 使用加盐加密对数据进行保存 前端页面使用vue搭建并打包放在static文件夹中 使用token保存当前用户 当用户登
  • chrome浏览器network报错:ERR_CERT_AUTHORITY_INVALID

    转载请注明作者 独孤尚良dugushangliang 出处 https blog csdn net dugushangliang article details 85275319 在访问局域网的某网址时 提示 您的连接不是私密连接 错误代码
  • 算法在ros中应用_烟火检测算法——中伟视界人工智能算法AI在智慧工地、石油中的应用_腾讯新闻...

    烟火检测算法功能说明及实现原理等 一 软件概述 视频智能分析基于目前先进的深度学习算法 通过大量的项目现场素材训练模型 通过本站大量采集的工作服素材 高精度的识别人 安全帽 工作服等识别 本项目主要两方面的算法 一是识别类的 二是行为分析
  • WPF中Datagrid其中一列使用图片显示

    实现效果 实现遇到的问题 当时想要实现如图所示 合格率 所示的效果 我的第一个想法就是使用wpf的转换器 可是接下来问题来了 我这个是通过数值来判断是否合格 什么控件可以做到既可以绑定图片类型的 又可以绑定数值类型的 还有此时的当值绑定肯定
  • 段、页、页框、页表、页表项

    段 页 页框 页表 页表项 分页式虚拟内存 页 页框 页表 页表项 段页式虚拟内存 分段 分页 段 段表 段表项 页 页框 页表 页表项 分页式虚拟内存 页 页框 页表 页表项 页 进程中的块 进程被分成许多大小相同的块 页号 页框 内存中
  • TS2769: Property 'xxx' does not exist on type 'IntrinsicAttributes & IntrinsicClassAttribute...

    用TypeScript开发React项目 在父子组件间传值时发生错误提示 class Page extends React Component render return div div
  • vue组件利用css var(--变量)实现动态修改伪类属性(::before、::after)

    如图所示 1 我们可以利用此属性实现vue组件动态传值 修改例如 before after等 伪类的背景色 背景图等属性值 因为vue利用无法直接在css中使用data里的变量 利用var 变量名 以及style中定义变量 其实此步是模仿
  • Coordinate attention,SE,CBAM

    1 SE 因为普通卷积难以建模信道关系 SE考虑通道的相互依赖关系增强模型对信息通道的敏感性 同时全局平均池化可以帮助模型捕获全局信息 然而SE只考虑了内部通道信息而忽略了位置信息的重要性 输入X首先经过全局平均池化 然后经过全连接层来捕获
  • 静态类和动态类的区别和使用

    1 静态类中的静态方法可以通过类名直接调用静态方法 不需要实例化对象 但是无法和Spring容器中的bean进行交互 例如 Slf4j public class ExcelUtil public static
  • 动态链接

    动态链接 命令 gcc static 产生静态库 shared 产生共享库 readelf d 查看 dynamic段的内容 ldd 查看一个程序主模块或一个共享库依赖于哪些共享库 一 静态链接和动态链接的优缺点 静态链接 空间的浪费 静态
  • Arduino结合HX711实现8路信号采集称重

    说明 使用两块Arduino实现8路Sensor同时采集 并输出控制信号 写作目的主要是为了作为学习笔记 Arduino Sensor接线图 1 双机通讯连线图 2 HX711和Sensor的连线图 3 将8个Sensor的SCK全部接到r
  • 键盘输入_bp

    依据惯例 仍然感谢出处 来自程序员的暴击 https space bilibili com 128373173 学习了下 这个说了个什么呢 人到达灯附近 显示提示文字 按F键开灯和关灯切换 远离灯时 提示文字消失 不能切换灯的切换开关状态
  • QT编译报错无法解析的外部符号

    QT编译报错无法解析的外部符号 特征 头文件 有几个槽函数 提示有多少个无法解析的外部符号 注释掉宏Q OBJECT 可以编译通过 可能原因 1 对应的cpp文件没有加入项目中 2 cpp文件 右键属性 为 自定义工具 没有进行编译 修改为
  • 华为、华三、锐捷、飞塔、山石的抓包命令

    一 华为的抓包命令 1 基本概念 华为的抓包行为称之为镜像端口 也就是说将需要抓取的接口上 称为镜像端口 的流量复制一份到另一个接口上 工程师进行流量观察的端口 称为观察端口 如下图所示 2 华为镜像端口分类 1 本地镜像端口 也就是观察端
  • Django框架:优缺点、实用场景及与Flask、FastAPI的对比

    Django是一个使用Python语言编写的高级Web框架 它提供了快速开发 可重用和可维护的Web应用程序所需的一切组件 在本文中 我们将探讨Django的get和post请求 优缺点 实用场景以及与Flask FastAPI的对比 Dj
  • windows中如何将收藏夹里的下载链接加入到开始

    windows中如何将收藏夹里的下载链接加入到开始 以windows 7为例 设置方法如下 1 右击工具栏 属性 2 开始菜单 自定义 下拉至下载 点中显示为链接 确定 3 可以看到 下载已经看到了
  • C# 泛型详解(泛型类,方法,接口,委托,约束,反射 )

    目录 一 什么是泛型 二 为什么要用泛型 三 泛型和Object类型的区别 四 泛型类 五 泛型方法 六 泛型接口 七 泛型委托 八 泛型约束 九 泛型配合反射 结束 一 什么是泛型 先看一段介绍 泛型 Generic 是将不确定的类型预先
  • 天梯题集——多项式A除以B(多项式除法,递归与循环的效率比较)

    多项式A除以B 多项式除法 这里就不展开介绍多项式除法 只需将多项式看成一个整体就类似于整数除法 x3 1 x 1 x2 x 1 多项式除法的演示图 解题思路 模拟 A B 多项式除法 方案一 递归 include
  • 抗渗等级p6是什么意思_混凝土p6是什么意思

    展开全部 40是混凝土的强度等62616964757a686964616fe58685e5aeb931333431356664级 P6是抗渗混凝土按抗渗压力 抗渗混凝土按抗渗压力不同分为P6 P8 P10 P12和大于P12共5个等级 抗渗
  • 面试题目搜集(5)

    本博客的 面试题目搜集系列不错 1 面试题目搜集1 2 面试题目搜集2 3 面试题目搜集3 4 面试题目搜集4 5 面试题目搜集5 6 面试题目搜集6 1 反着打印链表 递归实现 include