大公司C++面试题集锦(答案全)(4)

2019-03-29 08:04

3. 递归计算如下递归函数的值(斐波拉契): f(1)=1 f(2)=1

f(n)=f(n-1)+f(n-2) n>2 解:非递归算法: int f(int n) {

int i,s,s1,s2;

s1=1;/*s1用于保存f(n-1)的值*/ s2=1;/*s2用于保存f(n-2)的值*/ s=1;

for(i=3;i<=n;i++) {

s=s1+s2; s2=s1; s1=s; }

return(s); }

递归算法: Int f(int n) {

If(n==1||n==2) Rerurn 1; Else

Rerutn f(n-1)+f(n-2); }

4. 交换两个数,不用第三块儿内存:答:int a = ……; int b = ……; a = a + b; b = a - b; a = a - b;

5. 冒泡排序:

答:void BubbleSort(elemtype x[],int n) { int i,j;

elemtype temp; for(i=1;i

if(x[j].key>x[j+1].key) {

temp=x[j];

//时间复杂度为0(n*n);

x[j]=x[j+1]; x[j+1]=temp; } } }

//补充一个改进的冒泡算法:

void BubbleSort(elemtype x[],int n) {

Int i,j;

BOOL exchange; //记录交换标志 for(i=1;i

Exchange = false; For(j=n-1;j>=i;--j) {

If(x[j]>x[j+1]) {

x[0] = x[j]; X[j] = x[j+1]; X[j+1] = x[0];

Exchange = true; //发生了交换,设置标志为真. } }

if (!Exchange ) //为发生替换,提前终止算法 return; } }

6. c语言 文件读写 #include \main() {

FILE *fp;

char ch,filename[10]; scanf(\

if((fp=fopen(filename,\{

printf(\exit(0); }

ch=getchar(); while(ch!='#') {

fputc(ch,fp);

putchar(ch); ch=getchar(); }

fclose(fp); }

7. winsocket编程 //这个不错 // 服务器代码

#include #include void main() {

WORD wVersionRequested; //版本号 WSADATA wsaData; //数据 int err;

wVersionRequested = MAKEWORD(1,1);

err = WSAStartup(wVersionRequested,&wsaData); if( err != 0) {

return; }

if(LOBYTE( wsaData.wVersion ) != 1|| HIBYTE( wsaData.wVersion) != 1) {

WSACleanup(); return; }

SOCKET sockSrv=socket(AF_INET,SOCK_STREAM,0); //建立套接字 SOCKADDR_IN addrSrv;

addrSrv.sin_addr.S_un.S_addr=htonl(INADDR_ANY); addrSrv.sin_family=AF_INET; addrSrv.sin_port=htons(6000);

bind(sockSrv,(SOCKADDR*)&addrSrv,sizeof(SOCKADDR)); //绑定端口 listen(sockSrv,5); //转换socket套接子为侦听套接子 SOCKADDR_IN addrClient; int len=sizeof(SOCKADDR); while(1) //无限循环 {

SOCKET sockConn=accept(sockSrv,(SOCKADDR*)&addrClient,&len); char sendBuf[100];

sprint(sendBuf,\inet_ntoa(addrClient.sin_addr));

send(sockConn,sendBuf,strlen(sendBuf)+1,0); char recvBuf[100];

recv(sockConn,recvBuf); printf(\closesocket(sockConn); WSACleanup(); } }

注:这是Server端;File->New->Win32 Console Application,工程名:TcpSrv;然后,File->New->C++ Source File,文件名:TcpSrv;在该工程的Setting的Link的Object/library modules项要加入ws2_32.lib #include #include void main() {

WORD wVersionRequested; WSADATA wsaData; int err;

wVersionRequested = MAKEWORD(1,1);

err = WSAStartup(wVersionRequested,&wsaData); //启动winsock Dll if( err != 0) {

return; }

if(LOBYTE( wsaData.wVersion ) != 1|| HIBYTE( wsaData.wVersion) != 1) {

WSACleanup(); return; }

SOCKET sockClient=socket(AF_INET,SOCK_STREAM,0); SOCKADDR_IN addrSrv;

addrSrv.sin_addr.S_un.S_addr=inet_addr(\ addrSrv.sin_family=AF_INET; addrSrv.sin_port = htons(6000);

connect(sockClient,(SOCKADDR*)&addrSrv,sizeof(SOCKADDR)); char recvBuf[100];

recv(sockClient,recvBuf,100,0); printf(\

send(sockClient,\ closesocket(sockClient); WSACleanup(); }

注:这是Client端;File->New->Win32 Console Application,工程名:TcpClient;然后,File->New->C++ Source File,文件名:TcpClient;同理,在该工程的Setting的Link的Object/library modules项要加入ws2_32.lib

8. 类的知识 (非常不错的一道题目).. C++

#include class human {

public:

human(){ human_num++;}; //默认构造函数 static int human_num; //静态成员 ~human() {

human_num--; print(); }

void print() // {

cout<<\}

protected: private: };

int human::human_num = 0; //类中静态数据成员在外部定义,仅定义一次 human f1(human x) {

x.print(); return x; }

int main(int argc, char* argv[]) {

human h1; //调用默认构造函数,human_num变为1 h1.print(); // 打印Human_man:1

human h2 = f1(h1); //先调用函数f1(),输出human_num:1,而后输出human_num为0, h2.print();//打印输出:human_num:0 return 0;

} //依次调用两个析构函数:输出:human_num:-1,human_num:-2; 输出: 1 1 0 0 -1 -2

---------------------------- 分析:


大公司C++面试题集锦(答案全)(4).doc 将本文的Word文档下载到电脑 下载失败或者文档不完整,请联系客服人员解决!

下一篇:廉洁倡议书

相关阅读
本类排行
× 注册会员免费下载(下载后可以自由复制和排版)

马上注册会员

注:下载文档有可能“只有目录或者内容不全”等情况,请下载之前注意辨别,如果您已付费且无法下载或内容有问题,请联系我们协助你处理。
微信: QQ: