C语言开发工程师笔试题_第1页
C语言开发工程师笔试题_第2页
C语言开发工程师笔试题_第3页
已阅读5页,还剩8页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

Word———C语言开发工程师笔试题C语言之所以命名为C,是由于C语言源自KenThompson创造的B语言,而B语言则源自BCPL语言。下面我给大家共享C语言开发工程师笔试题的内容,盼望能够关心大家,欢迎阅读!

C语言开发工程师笔试题

1、改错

如下程序能不能正确输出,假如不能,让他正确输出hello字符串。

voidNew(char星符号p){p=newchar[5];}voidmain{char星符号p=NULL;New(p);strcpy(p,hello);printf(%s,p);}

2、排列算法

一个数组{3,4,5,6,3},请输出这个数组的全排列,比如34563、43563、33456...。

#include

#include

template

voidPrint(T星符号tArray,intiSize)

{

for(inti=0;iiSize;++i)

{

std::couttArray[i];

}

std::coutstd::endl;

}

template

voidPermutation(T星符号tArray,intiSize)

{

int星符号iIndex=newint[iSize+1];

for(inti=0;iiSize;++i)

{

iIndex[i]=iSize-i;

}

Print(tArray,iSize);

for(inti=iSize-1;i0;)

{

--iIndex[i];

--i;

intj=iSize-1;

do

{

if(tArray[j--]!=tArray[i++])

{

std::swap(tArray[j--],tArray[i++]);

}

}while(ji);

Print(tArray,iSize);

i=iSize-1;

for(;iIndex[i]==0;--i)

{

iIndex[i]=iSize-i;

}

}

deleteiIndex;

}

intmain

{

inta={3,4,5,6,3};

Permutation(a,5);

}

C++开发工程师笔试题篇

1、数据结构

在二叉树中找出和为某一输入值的全部路径。

#include

voidgetPath(structtreeNode星符号node,intsum,vectorstack,intcurrentSum){//stack用来存放路径,sum为输入值

}if(node==NULL)return;currentSum+=node-id;stack.push_back(node-id);if(node-lchild!=NULL)getPath(node-lchild,sum,stack,currentSum);if(node-rchild!=NULL)getPath(node-rchild,sum,stack,currentSum);if(node-lchild==NULLnode-rchild==NULL){if(currentSum==sum){vector::iteratorit=stack.begin;for(;it!=stack.end;++it)printf(%d,星符号it);printf(/n);}}stack.pop_back;

2、编写程序:如何获得一个整数的二进制表达中有多少个1?

C++开发工程师笔试题篇

1、编写程序:在O(n)时间简单度内从数组array[0..n-1]中找出第k个最小的元素。说明:算法可以对array中的元素进行排序。

2、综合考察:

银行有个存有n个用户编号的文件,每个数都小于n,其中n=10的7次方。每个编号都不重复。

输出:n个数升序排列。

约束条件:内存最多有2兆的空间,运行时间简单度为O(n)。

c++数据结构算法面试笔试题篇

1请你分别划划OSI的七层网络结构图,和TCP/IP的五层结构图?

2请你具体的解释一下IP协议的定义,在哪个层上面,主要有什么作用?TCP与UDP呢?UDP,TCP在传输层,IP在网络层,TCP/IP是英文TransmissionControlProtocol/InternetProtocol的缩写,意思是传输掌握协议/网际协议。TCP/IP协议组之所以流行,部分缘由是由于它可以用在各种各样的信道和底层协议(例如T1和X.25、以太网以及RS-232串行接口)之上。准确地说,TCP/IP协议是一组包括TCP协议和IP协议,UDP(UserDatagramProtocol)协议、ICMP(InternetControlMessageProtocol)协议和其他一些协议的协议组。TCP/IP协议并不完全符合OSI的七层参考模型。传统的开放式系统互连参考模型,是一种通信协议的7层抽象的参考模型,其中每一层执行某一特定任务。该模型的目的是使各种硬件在相同的层次上相互通信。这7层是:物理层、数据链路层、网路层、传输层、话路层、表示层和应用层。而TCP/IP通讯协议采纳了4层的层级结构,每一层都呼叫它的下一层所供应的网络来完成自己的需求。这4层分别为:

应用层:应用程序间沟通的层,如简洁电子邮件传输(SMTP)、文件传输协议(FTP)、网络远程访问协议(Telnet)等。

传输层:在此层中,它供应了节点间的数据传送服务,如传输掌握协议(TCP)、用户数据报协议(UDP)等,TCP和UDP给数据包加入传输数据并把它传输到下一层中,这一层负责传送数据,并且确定数据已被送达并接收。

互连网络层:负责供应基本的数据封包传送功能,让每一块数据包都能够到达目的主机(但不检查是否被正确接收),如网际协议(IP)。

网络接口层:对实际的网络媒体的管理,定义如何使用实际网络(如Ethernet、SerialLine等)来传送数据。

Q3:请问交换机和路由器分别的实现原理是什么?分别在哪个层次上面实现的?

一般意义上说交换机是工作在数据链路层。但随着科技的进展,现在有了三层交换机,三层交换机已经扩展到了网络层。也就是说:它等于“数据链路层+部分网络层”。交换机中传的是帧。通过存储转发来实现的。路由器是工作在网络层。路由器中传的是IP数据报。主要是选址和路由。

Q4:请问C++的类和C里面的struct有什么区分?

结构是一种将数据集合成组的方法,类是一种同时将函数和数据都集合成组的方法。结构和类在表面上的唯一区分是:类中的成员在默认状况下是私有的,而结构中的成员在默认状况下是公用的。

classfoo

{

private:

intdata1;

public:

voidfunc;

};

可以写成:

classfoo

{

intdata1;

public:

voidfunc;

};

由于在类中默认的是私有的,所以关键字private就可以不写了。

假如想用结构完成这个类所作的相同的事,就可以免去关键字public,并将公有成员放置在私有成员之前:

structfoo

{

voidfunc;

private:

intdata1;

};

Q5:请讲一讲析构函数和虚函数的用法和作用?

在JAVA里没有象C++中的,所谓的析构函数,由于当一个对象不在使用的时候,它会自动被垃圾回收器回收,所以也就用不着析构函数了,那个finalize也只有在被垃圾回收器回收,才会被执行,而且许多时候,垃圾回收器并不肯定执行,所以它不能当做C++中的,所谓的析构函数使用,虚函数在JAVA里也是没有的,比较象近的应当算是abstract。

Q6:全局变量和局部变量有什么区分?是怎么实现的?操作系统和编译器是怎么知道的?

1)、全局变量的作用用这个程序块,而局部变量作用于当前函数

2)、前者在内存中安排在全局数据区,后者安排在栈区

3)、生命周期不同:全局变量随主程序创建和创建,随主程序销毁而销毁,局部变量在局部函数内部,甚至局部循环体等内部存在,退出就不存在

4)、使用方式不同:通过声明后全局变量程序的各个部分都可以用到,局部变量只能在局部使用

Q7:一些寄存器的题目,主要是寻址和内存管理等一些学问。

Q8:8086是多少位的系统?在数据总线上是怎么实现的?

8086微处理器初次发布时,这块16位芯片仅包含29000个晶体管,运行速度为5MHz。而当今基于x86架构的奔腾4处理器,已经包含5500万个晶体管,运行速度提高了600倍以上,高达3.06GHz。

8086是高性能的第三代微处理器,是Intel系列的16位微处理器,它是采纳HMOS工艺制造的,内部包含约29,000个晶体管。

8086有16根数据线和20根地址线,由于可用20位地址,所以可寻址的地址空间达220即1M字节。8086工作时,只要一个5V电源和一相时钟,时钟频率为5MHz。后来,Intel公司推出的8086-1型微处理器时钟频率高达10MHz,8086-2型微处理器时钟频率达8MHz。

1、局部变量能否和全局变量重名

答:能,局部会屏蔽全局。要用全局变量,需要使用::

局部变量可以与全局变量同名,在函数内引用这个变量时,会用到同名的局部变量,而不会用到全局变量。对于有些编译器而言,在同一个函数内可以定义多个同名的局部变量,比如在两个循环体内都定义一个同名的局部变量,而那个局部变量的作用域就在那个循环体内。

2、如何引用一个已经定义过的全局变量

答:extern

可以用引用头文件的方式,也可以用extern关键字,假如用引用头文件方式来引用某个在头文件中声明的全局变理,假定你将那个变写错了,那么在编译期间会报错,假如你用extern方式引用时,假定你犯了同样的错误,那么在编译期间不会报错,而在连接期间报错。

3、全局变量可不行以定义在可被多个.C文件包含的头文件中为什么

答:可以,在不同的C文件中以static形式来声明同名全局变量。

可以在不同的C文件中声明同名的全局变量,前提是其中只能有一个C文件中对此变量赋初值,此时连接不会出错

c++数据结构算法面试笔试题篇

1、语句for(;1;)有什么问题它是什么意思

答:和while(1)相同。

2、do……while和while……do有什么区分

答:前一个循环一遍再推断,后一个推断以后再循环

3、请写出下列代码的输出内容以下是引用片段:

#include

main

{

inta,b,c,d;

a=10;

b=a++;

c=++a;

d=10星符号a++;

printf(b,c,d:%d,%d,%d,b,c,d);

return0;

}

答:10,12,120

4、static全局变量与一般的全局变量有什么区分static局部变量和一般局部变量有什么区分static函数与一般函数有什么区分

全局变量(外部变量)的说明之前再冠以static就构成了静态的全局变量。全局变量本身就是静态存储方式,静态全局变量当然也是静态存储方式。这两者在存储方式上并无不同。这两者的区分虽在于非静态全局变量的作用域是整个源程序,当一个源程序由多个源文件组成时,非静态的全局变量在各个源文件中都是有效的。而静态全局变量则限制了其作用域,即只在定义该变量的源文件内有效,在同一源程序的其它源文件中不能使用它。由于静态全局变量的作用域局限于一个源文件内,只能为该源文件内的函数公用,因此可以避开在其它源文件中引起错误。

从以上分析可以看出,把局部变量转变为静态变量后是转变了它的存储方式即转变了它的生存期。把全局变量转变为静态变量后是转变了它的作用域,限制了它的使用范围。static函数与一般函数作用域不同。仅在本文件。只在当前源文件中使用的函数应当说明为内部函数(static),内部函数应当在当前源文件中说明和定义。对于可在当前源文件以外使用的函数,应当在一个头文件中说明,要使用这些函数的源文件要包含这个头文件

static全局变量与一般的全局变量有什么区分:static全局变量只初使化一次,防止在其他文件单元中被引用;

static局部变量和一般局部变量有什么区分:static局部变量只被初始化一次,

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论