[C++面试题]之字符串
基本上求职者进行笔试时没有不考字符串的。字符串也是一种相对简单的数据结构,容易引起面试官反复发问。事实上,字符串也是考验程序员编程规范和编程习惯的重要考点。不要忽视这些细节,因为这些细节会体现你在操作系统、软件工程、边界内存处理等方面的知识掌握能力,也会成为企业是否录用你的参考因素。
1、怎样将整数转换成字符串数,并且不用函数 itoa ?
答案:
12345678910111213141516171819202122232425#include <iostream>
using
namespace
std;
int
main ()
{
int
num =12345,i=0,j=0;
char
temp[7],str[7];
while
(num)
{
temp[i]=num%10+
'0'
;
//将整数num从后往前的每一位数转换成char保存在temp中
i++;
num=num/10;
}
temp[i]=0;
cout<<
"temp:"
<<temp<<endl;
i=i-1;
//反转temp
while
(i>=0)
{
str[j++]=temp[i--];
}
str[j]=0;
cout<<
"string:"
<<str<<endl;
return
0;
}
如果可以使用 itoa函数的话,则十分简单,如下:
1234567891011121314#include <iostream>
#include <stdlib.h>
using
namespace
std;
//使用itoa函数
int
main ()
{
int
num=12345;
char
str[7];
itoa(num,str,10);
cout<<
"integer:"
<<num<<endl<<
"string:"
<<str<<endl;
return
0;
}
2、已知函数原型是 char *strcpy(char *strDest,const char *strSrc);,其中strDest是目的字符串,strSrc是源字符串。
(1)不调用C++/C的字符串库函数,请编写strcpy函数。
(2)strcpy函数把strSrc的内容复制到strDest,为什么还要char *类型返回值?
答案:
(1)代码如下:
12345678char
*
strcpy
(
char
*strDest,
const
char
*strSrc)
{
assert
((strDest!=NULL)&&(strSrc!=NULL));
char
*address=strDest;
while
((*strDest++=*strSrc++)!=
'\0'
)
NULL;
return
address;
}
(2)为了实现链式表达式,返回具体值。
例如:
1int
length=
strlen
(
strcpy
(strDest,
"hello world"
));
3、编写一个函数,作用是把一个char组成的字符串循环右移n个。比如原来是" abcdefghi “,如果n=2,移位后应该是 “hiabcdefg ”。
答案:
(1)使用标准库函数方法:
123456789void
LoopMove(
char
*pStr,
int
steps)
{
int
n=
strlen
(pStr)-steps;
char
temp[MAX_LEN];
strcpy
(temp,pStr+n);
strcpy
(temp+steps,pStr);
*(temp+
strlen
(pStr))=‘\0’;
strcpy
(pStr,temp);
}
(2)不使用标准库函数的方法:
CSDN上一道题(请看第五题和评论)
4、将一句话里的单词进行倒置,标点符号不倒置。比如一句话:i come from beijing.倒置后变成:beijing. from come i。
解析:解决该问题可以分为两步:第一步全盘置换该语句成:.gnijieb morf emoc i。第二步进行部分翻转,如果不是空格,则开始翻转单词。
答案:
具体代码如下:
1234567891011121314151617181920212223242526272829303132333435363738#include <iostream>
using
namespace
std;
int
main ()
{
int
num=-12345,i=0,j=0,flag=0,begin,end;
char
str[]=
"i come from beijing."
;
char
temp;
j=
strlen
(str)-1;
//第一步是进行全盘翻转
while
(j>i)
{
temp=str[i];
str[i++]=str[j];
str[j--]=temp;
}
//第二步进行部分翻转
i=0;
while
(str[i])
{
if
(str[i]!=
' '
)
{
begin=i;
while
(str[i] && str[i]!=
' '
)
i++;
//找到str[i]为空格符
i=i-1;
//空格符回退一个
end=i;
}
while
(end>begin)
//部分翻转
{
temp=str[begin];
str[begin++]=str[end];
str[end--]=temp;
}
i++;
}
cout<<
"string:"
<<str<<endl;
}
5、编程:输入一行字符串,找出其中出现的相同且长度最长的字符串,输出它及其首字符的位置。例如:“yyabcdabjcabceg”,输出结果应该为 abc和 3。
答案:
12345678910111213141516171819202122232425262728293031#include <iostream>
#include <string>
using
namespace
std;
int
main ()
{
string str,tep;
cout<<
"请输入字符串:"
;
cin>>str;
for
(
int
i=str.length()-1;i>1;i--)
{
for
(
int
j=0;j<str.length();j++)
{
if
(j+i<=str.length())
{
size_t
t=0;
size_t
num=0;
tep=str.substr(j,i);
//从大到小去字串
t=str.find(tep);
//正序查找
num=str.rfind(tep);
//逆序查找
if
(t!=num)
//如果两次查找的位置不一致说明存在重复
{
cout<<tep<<
" "
<<t+1<<endl;
return
0;
}
}
}
}
return
0;
}
C++面试题已经基本完成了,可能还有一些其它方面的题型,比如操作系统、数据库、软件测试、计算机网络等方面的内容。接下来几天可能会写一些这方面的内容,我们一起期待吧..
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构