以撒的结合重生图鉴 重生不能用鼠标操作了吗

&&&&& 基本上求职者进行笔试时没有不考字符串的。字符串也是一种相对简单的数据结构,容易引起面试官反复发问。事实上,字符串也是考验程序员编程规范和编程习惯的重要考点。不要忽视这些细节,因为这些细节会体现你在操作系统、软件工程、边界内存处理等方面的知识掌握能力,也会成为企业是否录用你的参考因素。
1、怎样将整数转换成字符串数,并且不用函数 itoa ?
&&& 答案:
#include &iostream&
int main ()
int num =12345,i=0,j=0;
char temp[7],str[7];
while(num)
temp[i]=num%10+'0'; //将整数num从后往前的每一位数转换成char保存在temp中
num=num/10;
temp[i]=0;
cout&&"temp:"&&temp&&
//反转temp
while (i&=0)
str[j++]=temp[i--];
cout&&"string:"&&str&&
&&& 如果可以使用 itoa函数的话,则十分简单,如下:
#include &iostream&
#include &stdlib.h&
//使用itoa函数
int main ()
int num=12345;
char str[7];
itoa(num,str,10);
cout&&"integer:"&&num&&endl&&"string:"&&str&&
2、已知函数原型是 char *strcpy(char *strDest,const char *strSrc);,其中strDest是目的字符串,strSrc是源字符串。
&&& (1)不调用C++/C的字符串库函数,请编写strcpy函数。
&&& (2)strcpy函数把strSrc的内容复制到strDest,为什么还要char *类型返回值?
&&& 答案:
(1)代码如下:
char *strcpy(char *strDest,const char *strSrc)
assert((strDest!=NULL)&&(strSrc!=NULL));
char *address=strD
while((*strDest++=*strSrc++)!='\0')
(2)为了实现链式表达式,返回具体值。
int length=strlen(strcpy(strDest,"hello world"));
3、编写一个函数,作用是把一个char组成的字符串循环右移n个。比如原来是" abcdefghi &,如果n=2,移位后应该是 &hiabcdefg &。
&&& 答案:
(1)使用标准库函数方法:
void LoopMove(char *pStr,int steps)
int n=strlen(pStr)-
char temp[MAX_LEN];
strcpy(temp,pStr+n);
strcpy(temp+steps,pStr);
*(temp+strlen(pStr))=&\0&;
strcpy(pStr,temp);
(2)不使用标准库函数的方法:
(请看第五题和评论)
4、将一句话里的单词进行倒置,标点符号不倒置。比如一句话:i come from beijing.倒置后变成:beijing. from come i。
&&&&& 解析:解决该问题可以分为两步:第一步全盘置换该语句成:.gnijieb morf emoc i。第二步进行部分翻转,如果不是空格,则开始翻转单词。
&&&&& 答案:
具体代码如下:
#include &iostream&
int main ()
int num=-12345,i=0,j=0,flag=0,begin,
char str[]="i come from beijing.";
j=strlen(str)-1;
//第一步是进行全盘翻转
while(j&i)
temp=str[i];
str[i++]=str[j];
//第二步进行部分翻转
while(str[i])
if(str[i]!=' ')
while(str[i] && str[i]!=' ')
//找到str[i]为空格符
//空格符回退一个
while(end&begin) //部分翻转
temp=str[begin];
str[begin++]=str[end];
str[end--]=
cout&&"string:"&&str&&
5、编程:输入一行字符串,找出其中出现的相同且长度最长的字符串,输出它及其首字符的位置。例如:&yyabcdabjcabceg&,输出结果应该为 abc和 3。
&&& 答案:
#include &iostream&
#include &string&
int main ()
string str,
cout&&"请输入字符串:";
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&&
&&& C++面试题已经基本完成了,可能还有一些其它方面的题型,比如操作系统、数据库、软件测试、计算机网络等方面的内容。接下来几天可能会写一些这方面的内容,我们一起期待吧..
阅读(...) 评论()(凉凉凉凉凉粉)
第三方登录:

我要回帖

更多关于 以撒的结合重生 的文章

 

随机推荐