C/C 程式设计员应聘常见面试试题深入剖析(3)
2008-02-23 05:35:19来源:互联网 阅读 ()
函数头是这样的:
//steps是需要移动的n
void LoopMove ( char * pStr, int steps )
{
//请填充...
}
正确解答1:
{
int n = strlen( pStr ) - steps;
char tmp[MAX_LEN];
strcpy ( tmp, pStr n );
strcpy ( tmp steps, pStr);
*( tmp strlen ( pStr ) ) = '\0';
strcpy( pStr, tmp );
}
{
int n = strlen( pStr ) - steps;
char tmp[MAX_LEN];
memcpy( tmp, pStr n, steps );
memcpy(pStr steps, pStr, n );
memcpy(pStr, tmp, steps );
}
这个试题主要考查面试者对标准库函数的熟练程度,在需要的时候引用库函数能够很大程度上简化程式编写的工作量。
最频繁被使用的库函数包括:
(1) strcpy
(2) memcpy
(3) memset
试题6:已知WAV文档格式如下表,打开一个WAV文档,以适当的数据结构组织WAV文档头并解析WAV格式的各项信息。
WAVE文档格式说明表
偏移地址 | 字节数 | 数据类型 | 内 容 | |
文档头 | 00H | 4 | Char | "RIFF"标志 |
04H | 4 | int32 | 文档长度 | |
08H | 4 | Char | "WAVE"标志 | |
0CH | 4 | Char | "fmt"标志 | |
10H | 4 | 过渡字节(不定) | ||
14H | 2 | int16 | 格式类别 | |
16H | 2 | int16 | 通道数 | |
18H | 2 | int16 | 采样率(每秒样本数),表示每个通道的播放速度 | |
1CH | 4 | int32 | 波形音频数据传送速率 | |
20H | 2 | int16 | 数据块的调整数(按字节算的) | |
22H | 2 | 每样本的数据位数 | ||
24H | 4 | Char | 数据标记符"data" | |
28H | 4 | int32 | 语音数据的长度 |
将WAV文档格式定义为结构体WAVEFORMAT:
{
char cRiffFlag[4];
UIN32 nFileLen;
char cWaveFlag[4];
char cFmtFlag[4];
char cTransition[4];
UIN16 nFormatTag ;
UIN16 nChannels;
UIN16 nSamplesPerSec;
UIN32 nAvgBytesperSec;
UIN16 nBlockAlign;
UIN16 nBitNumPerSample;
char cDataFlag[4];
UIN16 nAudioLength;
} WAVEFORMAT;
memcpy( &waveFormat, buffer,sizeof( WAVEFORMAT ) );
剖析:
试题6考查面试者组织数据结构的能力,有经验的程式设计者将属于一个整体的数据成员组织为一个结构体,利用指针类型转换,能够将memcpy、memset等函数直接用于结构体地址,进行结构体的整体操作。 透过这个题能够看出面试者的程式设计经验是否丰富。
试题7:编写类String的构造函数、析构函数和赋值函数,已知类String的原型为:
{
public:
String(const char *str = NULL); // 普通构造函数
String(const String &other); // 拷贝构造函数
~ String(void); // 析构函数
String & operate =(const String &other); // 赋值函数
private:
char *m_data; // 用于保存字符串
};
String::String(const char *str)
{
if(str==NULL)
{
m_data = new char[1]; // 得分点:对空字符串自动申请存放结束标志'\0'的空
//加分点:对m_data加NULL 判断
*m_data = '\0';
}
else
{
int length = strlen(str);
m_data = new char[length 1]; // 若能加 NULL 判断则更好
strcpy(m_data, str);
}
}
// String的析构函数
String::~String(void)
{
delete [] m_data; // 或delete m_data;
}
//拷贝构造函数
String::String(const String &other) // 得分点:输入参数为const型
{
int length = strlen(other.m_data);
m_data = new char[length 1]; //加分点:对m_data加NULL 判断
strcpy(m_data, other.m_data);
}
//赋值函数
String & String::operate =(const String &other) // 得分点:输入参数为const型
{
if(this == &other) //得分点:检查自赋值
return *this;
delete [] m_data; //得分点:释放原有的内存资源
int length = strlen( other.m_data );
m_data = new char[length 1]; //加分点:对m_data加NULL 判断
标签:
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有
- C/C 程式设计员应聘常见面试试题深入剖析 2008-02-23
- C/C 程式设计员应聘常见面试试题深入剖析(2) 2008-02-23
IDC资讯: 主机资讯 注册资讯 托管资讯 vps资讯 网站建设
网站运营: 建站经验 策划盈利 搜索优化 网站推广 免费资源
网络编程: Asp.Net编程 Asp编程 Php编程 Xml编程 Access Mssql Mysql 其它
服务器技术: Web服务器 Ftp服务器 Mail服务器 Dns服务器 安全防护
软件技巧: 其它软件 Word Excel Powerpoint Ghost Vista QQ空间 QQ FlashGet 迅雷
网页制作: FrontPages Dreamweaver Javascript css photoshop fireworks Flash