网上找到的题目

简介: CC++ 题集(CC++试题和部分答案)1. 以下三条输出语句分别输出什么?[C易] char str1[]       = "abc"; char str2[]       = "abc"; const char str3[] = "abc";  const char str4[] = "abc"...

CC++ 题集(CC++试题和部分答案)
1. 以下三条输出语句分别输出什么?[C易]
char str1[]       = "abc";
char str2[]       = "abc";
const char str3[] = "abc"; 
const char str4[] = "abc"; 
const char* str5   = "abc";
const char* str6   = "abc";
cout << boolalpha << ( str1==str2 ) << endl; // 输出什么?
cout << boolalpha << ( str3==str4 ) << endl; // 输出什么?
cout << boolalpha << ( str5==str6 ) << endl; // 输出什么?
 
 
2. 非C++内建型别 A 和 B,在哪几种情况下B能隐式转化为A?[C++中等]
答:
a. class B : public A { ……} // B公有继承自A,可以是间接继承的
b. class B { operator A( ); } // B实现了隐式转化为A的转化
c. class A { A( const B& ); } // A实现了non-explicit的参数为B(可以
有其他带默认值的参数)构造函数
d. A& operator= ( const A& ); // 赋值操作,虽不是正宗的隐式类型转换,
但也可以勉强算一个
 
3. 以下代码中的两个sizeof用法有问题吗?[C易]
void UpperCase( char str[] ) // 将 str 中的小写字母转换成大写字母
{
     for( size_t i=0; i         if( 'a'<=str[i] && str[i]<='z' )
             str[i] -= ('a'-'A' );
}
char str[] = "aBcDe";
cout << "str字符长度为: " << sizeof(str)/sizeof(str[0]) << endl;
UpperCase( str );
cout << str << endl;
 
4. 以下代码有什么问题?[C难]
void char2Hex( char c ) // 将字符以16进制表示
{
     char ch = c/0x10 + '0'; if( ch > '9' ) ch += ('A'-'9'-1);
     char cl = c%0x10 + '0'; if( cl > '9' ) cl += ('A'-'9'-1);
     cout << ch << cl << ' ';
}
char str[] = "I love 中国";
for( size_t i=0; i     char2Hex( str[i] );
cout << endl;
 
5. 以下代码有什么问题?[C++易]
struct Test
{
     Test( int ) {}
     Test() {}
     void fun() {}
};
void main( void )
{
     Test a(1);
     a.fun();
     Test b();
     b.fun();
}
 
6. 以下代码有什么问题?[C++易]
cout << (true?1:"1") << endl;
 
7. 以下代码能够编译通过吗,为什么?[C++易]
unsigned int const size1 = 2;
char str1[ size1 ];
unsigned int temp = 0;
cin >> temp;
unsigned int const size2 = temp;
char str2[ size2 ];
 
8. 以下代码中的输出语句输出0吗,为什么?[C++易]
struct CLS
{
     int m_i;
     CLS( int I ) : m_i(i) {}
     CLS()
     {
         CLS(0);
     }
};
CLS obj;
cout << obj.m_i << endl;
 
9. C++中的空类,默认产生哪些类成员函数?[C++易]
答:
class Empty
{
public:
     Empty();                           // 缺省构造函数
     Empty( const Empty& );             // 拷贝构造函数
     ~Empty();                         // 析构函数
     Empty& operator=( const Empty& ); // 赋值运算符
     Empty* operator&();               // 取址运算符
     const Empty* operator&() const;   // 取址运算符 const
};
 
10. 以下两条输出语句分别输出什么?[C++难]
float a = 1.0f;
cout << (int)a << endl;
cout << (int&)a << endl;
cout << boolalpha << ( (int)a == (int&)a ) << endl; // 输出什么?
Float b = 0.0f;
cout << (int)b << endl;
cout << (int&)b << endl;
cout << boolalpha << ( (int)b == (int&)b ) << endl; // 输出什么?
 
11. 以下反向遍历array数组的方法有什么错误?[STL易]
vector array;
array.push_back( 1 );
array.push_back( 2 );
array.push_back( 3 );
for( vector::size_type i=array.size()-1; i>=0; --I ) // 反向遍历array
数组
{
     cout << array[i] << endl;
}
 
12. 以下代码有什么问题?[STL易]
typedef vector IntArray;
IntArray array;
array.push_back( 1 );
array.push_back( 2 );
array.push_back( 2 );
array.push_back( 3 );
// 删除array数组中所有的2
for( IntArray::iterator itor=array.begin(); itor!=array.end(); ++itor )
{
     if( 2 == *itor ) array.erase( itor );
}
 
13. 写一个函数,完成内存之间的拷贝。[考虑问题是否全面]
答:
void* mymemcpy( void *dest, const void *src, size_t count )
{
     char* pdest = static_cast( dest );
     const char* psrc = static_cast( src );
     if( pdest>psrc && pdest     {
         for( size_t i=count-1; i!=-1; --I )
                 pdest[i] = psrc[i];
     }
     else
     {
         for( size_t i=0; i             pdest[i] = psrc[i];
     }
     return dest;
}
int main( void )
{
     char str[] = "0123456789";
     mymemcpy( str+1, str+0, 9 );
     cout << str << endl;
 
     system( "Pause" );
     return 0;
}
 
 
本试题仅用于考查C++/C程序员的基本编程技能。内容限于C++/C常用语法,不
涉及数据结构、算法以及深奥的语法。考试成绩能反映出考生的编程质量以及对
C++/C的理解程度,但不能反映考生的智力和软件开发能力。
笔试时间90分钟。请考生认真答题,切勿轻视。
 
 
一、请填写BOOL , float, 指针变量 与“零值”比较的 if 语句。(10分)
 
提示:这里“零值”可以是0, 0.0 , FALSE或者“空指针”。例如 int 变量 n
与“零值”比较的 if 语句为:
 
if ( n == 0 )
if ( n != 0 )
以此类推。
 
请写出 BOOL flag 与“零值”比较的 if 语句:
请写出 float x 与“零值”比较的 if 语句:
请写出 char *p 与“零值”比较的 if 语句:
 
二、以下为Windows NT下的32位C++程序,请计算sizeof的值(10分)
char str[] = “Hello” ;
char *p = str ;
int n = 10;
请计算
sizeof (str ) = 
sizeof ( p ) = 
sizeof ( n ) =
void Func ( char str[100])
{
请计算
sizeof( str ) = 
}
 
void *p = malloc( 100 );
请计算
sizeof ( p ) =
 
三、简答题(25分)
1、头文件中的 ifndef/define/endif 干什么用?
2、#include 和 #include “filename.h” 有什么区别?
3、const 有什么用途?(请至少说明两种)
4、在C++ 程序中调用被 C编译器编译后的函数,为什么要加 extern “C”声
明?
5、请简述以下两个for循环的优缺点
// 第一个
for (i=0; i++;)
{
if (condition)
DoSomething();
else
DoOtherthing();
}
// 第二个
 
if (condition)
{
for (i=0; i++;)
DoSomething();
}
else
{
for (i=0; i++;)
DoOtherthing();
}
 
优点:
缺点:
优点:
缺点:
 
四、有关内存的思考题(20分)
void GetMemory(char *p)
{
p = (char *)malloc(100);
}
 
void Test(void) 
{
char *str = NULL;
GetMemory(str); 
strcpy(str, "hello world");
printf(str);
}
 
 
请问运行Test函数会有什么样的结果?
 
答:
char *GetMemory(void)

char p[] = "hello world";
return p;
}
 
void Test(void)
{
char *str = NULL;
str = GetMemory(); 
printf(str);
}
 
 
请问运行Test函数会有什么样的结果?
答:
Void GetMemory2(char **p, int num)
{
*p = (char *)malloc(num);
}
 
void Test(void)
{
char *str = NULL;
GetMemory(&str, 100);
strcpy(str, "hello"); 
printf(str); 
}
 
请问运行Test函数会有什么样的结果?
 
答:
void Test(void)
{
char *str = (char *) malloc(100);
strcpy(str, “hello”);
free(str); 
if(str != NULL)
{
strcpy(str, “world”); 
printf(str);
}
}
 
请问运行Test函数会有什么样的结果?
 
答:
 
五、编写strcpy函数(10分)
已知strcpy函数的原型是
char *strcpy(char *strDest, const char *strSrc);
其中strDest是目的字符串,strSrc是源字符串。
(1)不调用C++/C的字符串库函数,请编写函数 strcpy
(2)strcpy能把strSrc的内容复制到strDest,为什么还要char * 类型的返
回值?
 
六、编写类String的构造函数、析构函数和赋值函数(25分)
已知类String的原型为:
class String
{
public:
String(const char *str = NULL); // 普通构造函数
String(const String &other); // 拷贝构造函数
~ String(void); // 析构函数
String & operate =(const String &other); // 赋值函数
 
private:
char *m_data; // 用于保存字符串
};
 
请编写String的上述4个函数。
 
文章出自http://www.ad0.cn/
文章出自网魂工作室http://www.ad0.cn/
附录C :C++/C试题的答案与评分标准
一、请填写BOOL , float, 指针变量 与“零值”比较的 if 语句。(10分)
 
请写出 BOOL flag 与“零值”比较的 if 语句。(3分)
 
标准答案:
if ( flag )
if ( !flag )
如下写法均属不良风格,不得分。
 
If (flag == TRUE) 
if (flag == 1 ) 
if (flag == FALSE) 
if (flag == 0) 
 
请写出 float x 与“零值”比较的 if 语句。(4分)
 
标准答案示例:
 
const float EPSINON = 0.00001;
if ((x >= - EPSINON) && (x <= EPSINON)
不可将浮点变量用“==”或“!=”与数字比较,应该设法转化成“>=”或“<=”
此类形式。
 
如下是错误的写法,不得分。
 
If (x == 0.0) 
if (x != 0.0) 
 
 
 
请写出 char *p 与“零值”比较的 if 语句。(3分)
 
标准答案:
 
if (p == NULL)
if (p != NULL)
如下写法均属不良风格,不得分。
 
If (p == 0) 
if (p != 0) 
 
if (p) 
if (!) 
 
二、以下为Windows NT下的32位C++程序,请计算sizeof的值(10分)
char str[] = “Hello” ;
char *p = str ;
int n = 10;
请计算
sizeof (str ) = 6 (2分) 
sizeof ( p ) = 4 (2分)
sizeof ( n ) = 4 (2分)
void Func ( char str[100])
{
请计算
sizeof( str ) = 4 (2分)
}
 
void *p = malloc( 100 );
请计算
sizeof ( p ) = 4 (2分)
 
三、简答题(25分)
1、头文件中的 ifndef/define/endif 干什么用?(5分)
答:防止该头文件被重复引用。
 
2、#include 和 #include “filename.h” 有什么区别?(5分)
 
华为的CC++面试题
 
Q1:请你分别划划OSI的七层网络结构图,和TCP/IP的五层结构图? 
: Q2:请你详细的解释一下IP协议的定义,在哪个层上面,主要有什么作用? 
: TCP与UDP呢? 
: 总得来说前面两道题目还是比较简单的! 
: Q3:请问交换机和路由器分别的实现原理是什么?分别在哪个层次上面实 
: 现的? 
: Q4:请问C++的类和C里面的struct有什么区别? 
: Q5:请讲一讲析构函数和虚函数的用法和作用? 
: Q6:全局变量和局部变量有什么区别?实怎么实现的?操作系统和编译器 
: 是怎么知道的? 
: Q7:一些寄存器的题目,我忘记了具体实什么题目,主要好像是寻址和内 
: 存管理等一些知识,不记得了。 
: Q8:8086是多少尉的系统?在数据总线上是怎么实现的?还有一些硬件方 
: 面的知识我既不清楚了。 
 
: 一般建议参加华为的研发面试的同学先要准备一下相关的知识,软件的主要 
: 是看看C和数据结构方面的,硬件模电,数电和微机原理 
 
两道c面试题 
    
1、一个学生的信息是:姓名,学号,性别,年龄等信息,用一个链表,把这些
学生信息连在一起, 给出一个age, 在些链表中删除学生年龄等于age的学生
信息。
#I nclude \"stdio.h\"
#I nclude \"conio.h\"
 
struct stu{
     char name[20];
     char sex;
     int no;
     int age;
     struct stu * next;
}*linklist;
struct stu *creatlist(int n)
{
     int I;
     //h为头结点,p为前一结点,s为当前结点
     struct stu *h,*p,*s;
     h = (struct stu *)malloc(sizeof(struct stu));
     h->next = NULL;
     p=h;
     for(i=0;i     {   
         s = (struct stu *)malloc(sizeof(struct stu));
         p->next = s;
         printf(\"Please input the information of the student: name sex
no age n\");
         scanf(\"%s %c %d %d\",s->name,&s->sex,&s->no,&s->age);
         s->next = NULL;
         p = s;
     }
     printf(\"Create successful!\");
     return(h);
}
void deletelist(struct stu *s,int a)
{
struct stu *p;
while(s->age!=a)
{
   p = s;
   s = s->next;
}
if(s==NULL)
   printf(\"The record is not exist.\");
else
{
   p->next = s->next;
   printf(\"Delete successful!\");
}
}
void display(struct stu *s)
{
s = s->next;
     while(s!=NULL)
     {
         printf(\"%s %c %d %dn\",s->name,s->sex,s->no,s->age);
         s = s->next;
     }
}
int main()
{
     struct stu *s;
int n,age;
printf(\"Please input the length of seqlist:n\");
scanf(\"%d\",&n);
     s = creatlist(n);
     display(s);
printf(\"Please input the age:n\");
scanf(\"%d\",&age);
deletelist(s,age);
display(s);
     return 0;
}
 
 
2、实现一个函数,把一个字符串中的字符从小写转为大写。
#I nclude \"stdio.h\"
#I nclude \"conio.h\"
 
void uppers(char *s,char *us)
{
     for(;*s!='0';s++,us++)
     {
         if(*s>='a'&&*s<='z')
             *us = *s-32;
         else
             *us = *s;
     }
     *us = '0';
}
int main()
{
     char *s,*us;
     char ss[20];
     printf(\"Please input a string:n\");
     scanf(\"%s\",ss);
     s = ss;
     uppers(s,us);
     printf(\"The result is:n%sn\",us);
     getch();
}


C/C++面试题大汇总之微软亚洲技术中心面试题
1.进程和线程的差别。
2.测试方法 
3.Heap与stack的差别。
4.Windows下的内存是如何管理的?
5.介绍.Net和.Net的安全性。
6.客户端如何访问.Net组件实现Web Service?
7.C/C++编译器中虚表是如何完成的?
8.谈谈COM的线程模型。然后讨论进程内/外组件的差别。
9.谈谈IA32下的分页机制
10.给两个变量,如何找出一个带环单链表中是什么地方出现环的?
11.在IA32中一共有多少种办法从用户态跳到内核态?
12.如果只想让程序有一个实例运行,不能运行两个。像winamp一样,只能开一个窗口,
怎样实现?
13.如何截取键盘的响应,让所有的‘a’变成‘b’?
14.Apartment在COM中有什么用?为什么要引入?
15.存储过程是什么?有什么用?有什么优点?
16.Template有什么特点?什么时候用?
17.谈谈Windows DNA结构的特点和优点。
18.网络编程中设计并发服务器,使用多进程与多线程 ,请问有什么区别?

 

相关文章
|
1月前
|
容器
数组刷题总结,快来检查一下是不是都掌握了吧~
数组刷题总结,快来检查一下是不是都掌握了吧~
34 0
|
3月前
leetcode-2115:从给定原材料中找到所有可以做出的菜
leetcode-2115:从给定原材料中找到所有可以做出的菜
23 0
|
4月前
|
算法 Java
刷题专栏(二十八):找到所有数组中消失的数字
刷题专栏(二十八):找到所有数组中消失的数字
101 4
|
5月前
|
算法
代码随想录算法训练营第三十九天 | LeetCode 62. 不同路径、63. 不同路径 II
代码随想录算法训练营第三十九天 | LeetCode 62. 不同路径、63. 不同路径 II
26 1
|
6月前
|
Go
SQLZOO 答案—完整版(下)
SQLZOO 答案—完整版(下)
|
6月前
|
SQL 关系型数据库 MySQL
SQLZOO 答案—完整版(上)
SQLZOO 答案—完整版(上)
|
定位技术
代码随想录刷题|LeetCode 62.不同路径 63. 不同路径 II
代码随想录刷题|LeetCode 62.不同路径 63. 不同路径 II
代码随想录刷题|LeetCode 62.不同路径 63. 不同路径 II
|
算法 索引
【切图仔的算法修炼之旅】LeetCode1991:找到数组中的中间位置
【切图仔的算法修炼之旅】LeetCode1991:找到数组中的中间位置
87 0
|
存储
LeetCode 1 梦开始的地方
LeetCode 1 梦开始的地方
57 0
|
Java
《LeetCode刷题》—448. 找到所有数组中消失的数字
《LeetCode刷题》—448. 找到所有数组中消失的数字
92 0
《LeetCode刷题》—448. 找到所有数组中消失的数字

热门文章

最新文章