自己整理的几个C面试小题
2017-09-14 10:15
302 查看
概念题:
1.c++中为什么用模板类?
a.与类型无关,具有很高的可复用性。
b.他在编译的时而不是运行时候检查数据类型,保证了类型安全性
c.他与平台无关的,具有可已移植性
d.可用于基本数据类型
e.可用来创建动态增长和减小数据结构 //?????
2.简介多态,虚函数,纯虚函数
多态:一个接口(方法),实现不同种功能
虚函数:用virtual修饰的重写方法
纯虚函数:在虚函数后面加上=0,告诉编译器这是纯虚函数
/*
如果在父类定义虚函数,那么在定义对象时,如果用父类定义对象,则执行父类的函数体
如果用子类定义对象,那么执行子类的函数体,这就实现了一个接口,不同功能的作用
*/
3.inline函数与非inline区别?
inline函数为内联函数,在函数调用时直接调用,而没有上下文环境
非inline在函数调用时则会保存上下文环境。
4.什么是函数重载?
允许函数名相同,但参数的类型或者参数的个数不能相同,并且不可以以返回值类型重载。
5.const在c++跟c中的不同?
C中的const:被修饰的内容不可以被改变,使用场合:修饰变量,函数参数,返回值等。
而且c中的const默认时外部链接,因此在不同编译单元中,如果有同名的const则会报错
C++中的const:1.类外的const默认时内部链接的,因才在不同的编译单元中可以重名
2.它是编译时常量,因此可以像#define一样使用,因此可以在头文件定义const变量,
并且在其包含的不同的cpp文件中使用不会引起命名冲突。
3.类中的const,与c语言中的一样
类中的const变量占用内存空间
类中的const成员变量,需要在构造函数初始化列表中初始化
引用与指针有什么区别?
『指针』是一个变量,只不过这个变量存储的是一个地址,指向内存的一个存储单元。
『引用』跟原来的变量实质上是一个东西,只不过是原变量的一个别名
指针有多级的,而引用只有一级的
指针可以用const修饰,引用不可以
指针可以赋值NULL,引用不可以
sizeof指针:指针的大小
sizeof引用:所指变量(对象的)大小
malloc与new的区别?
1.malloc和free是c/c++语言的标准库函数,new/delete是运算符。他们都可以申请动态内存和释放
2.对于非内部数据类型的对象而言,malloc/free无法满足动态对象的要求。即定义对象时自动调用构造函数,对象结束时自动执行析构函数。
malloc/free可以在c和c++中使用,而new/delete只能在c++中使用。
new出来的指针带直接带类型信息的,相当与malloc加构造函数的执行。
编程题:
/*编程实现,对于输入任何一个非负数,打印输出与其等值的六进制数
* */
#include <stdio.h>
int power(int num,int index)
{
int i;
int sum = 1;
for(i=0;i<index;i++)
{
sum = sum * 10;
}
sum = num * sum;
return sum;
}
int main()
{
int temp;
int sum = 0,res;
int num,i=0;
printf("输入一个非负数\n");
scanf("%d",&num);
while(num != 0)
{
temp = num % 6;
num = num / 6;
sum = sum + power(temp,i);
i++;
}
printf("%d\n",sum);
return 0;
}
1.c++中为什么用模板类?
a.与类型无关,具有很高的可复用性。
b.他在编译的时而不是运行时候检查数据类型,保证了类型安全性
c.他与平台无关的,具有可已移植性
d.可用于基本数据类型
e.可用来创建动态增长和减小数据结构 //?????
2.简介多态,虚函数,纯虚函数
多态:一个接口(方法),实现不同种功能
虚函数:用virtual修饰的重写方法
纯虚函数:在虚函数后面加上=0,告诉编译器这是纯虚函数
/*
如果在父类定义虚函数,那么在定义对象时,如果用父类定义对象,则执行父类的函数体
如果用子类定义对象,那么执行子类的函数体,这就实现了一个接口,不同功能的作用
*/
3.inline函数与非inline区别?
inline函数为内联函数,在函数调用时直接调用,而没有上下文环境
非inline在函数调用时则会保存上下文环境。
4.什么是函数重载?
允许函数名相同,但参数的类型或者参数的个数不能相同,并且不可以以返回值类型重载。
5.const在c++跟c中的不同?
C中的const:被修饰的内容不可以被改变,使用场合:修饰变量,函数参数,返回值等。
而且c中的const默认时外部链接,因此在不同编译单元中,如果有同名的const则会报错
C++中的const:1.类外的const默认时内部链接的,因才在不同的编译单元中可以重名
2.它是编译时常量,因此可以像#define一样使用,因此可以在头文件定义const变量,
并且在其包含的不同的cpp文件中使用不会引起命名冲突。
3.类中的const,与c语言中的一样
类中的const变量占用内存空间
类中的const成员变量,需要在构造函数初始化列表中初始化
引用与指针有什么区别?
『指针』是一个变量,只不过这个变量存储的是一个地址,指向内存的一个存储单元。
『引用』跟原来的变量实质上是一个东西,只不过是原变量的一个别名
指针有多级的,而引用只有一级的
指针可以用const修饰,引用不可以
指针可以赋值NULL,引用不可以
sizeof指针:指针的大小
sizeof引用:所指变量(对象的)大小
malloc与new的区别?
1.malloc和free是c/c++语言的标准库函数,new/delete是运算符。他们都可以申请动态内存和释放
2.对于非内部数据类型的对象而言,malloc/free无法满足动态对象的要求。即定义对象时自动调用构造函数,对象结束时自动执行析构函数。
malloc/free可以在c和c++中使用,而new/delete只能在c++中使用。
new出来的指针带直接带类型信息的,相当与malloc加构造函数的执行。
编程题:
/*编程实现,对于输入任何一个非负数,打印输出与其等值的六进制数
* */
#include <stdio.h>
int power(int num,int index)
{
int i;
int sum = 1;
for(i=0;i<index;i++)
{
sum = sum * 10;
}
sum = num * sum;
return sum;
}
int main()
{
int temp;
int sum = 0,res;
int num,i=0;
printf("输入一个非负数\n");
scanf("%d",&num);
while(num != 0)
{
temp = num % 6;
num = num / 6;
sum = sum + power(temp,i);
i++;
}
printf("%d\n",sum);
return 0;
}
/*编程实现,在已知字符串中查找子串,并返回第一个子串的首地址,如果没有返回空 * */ #include <stdio.h> #include <string.h> char *findSub(char *a,char *b) { int i,j,k = 0; for(i=0;i<strlen(a);i++) { if(a[i] == b[0]) { for(j=0;j<strlen(b);j++) { if(a[i+j] == b[j]) { k++; if(k == strlen(b)) { return a+i; } } } k = 0; } } printf("无子串\n"); return NULL; } int main() { char a[] = "asdfjhqklfhs"; char b[] = "sd"; char *p = NULL; printf("%p\n",a); p = findSub(a,b); printf("%p\n",p); return 0; }
/*"标识符"是由小写字母,大写字母,数字组成的字符串 * 1.大写字母后面不能是数字 * 2.首字母不能是数字 * */ #include <stdio.h> #include <string.h> int low(char ch){ if(ch>='a' && ch<='z'){ return 1; }else{ return 0; } } int up(char ch){ if(ch>='A' && ch<='Z'){ return 1; }else{ return 0; } } int num(char ch){ if(ch>='0' && ch<='9'){ return 1; }else{ return 0; } } int main() { char arr[]= "as233dfdAHJASD"; char *p = arr; int i; int flag = 0; for(i=0;i<strlen(arr);i++){ if(!up(arr[i]) && !low(arr[i]) && !num(arr[i])){ printf("必须由大小写字母,数字组成\n"); return 1; } } if(num(*p) == 1){ printf("首字母不能是数字\n"); return 2; } while(*p != '\0') { if(flag && num(*p)){ printf("大写字母后面不能是数字\n"); return 3; } if(up(*p)){ flag = 1; }else{ flag = 0; } p++; } printf("right!\n"); return 0; }
/*一个数如果等于他的因子之和,这个数称之为“完数”,例如6=1+2+3 *编程找出1000以内的所有完数 * */ #include <stdio.h> int isRight(int num) { int sum = 0; int i; for(i=1;i<num;i++) { if(num%i == 0) { sum = sum + i; } } return sum; } int main() { int i; for(i=1;i<1000;i++) { if(i == isRight(i)) { printf("%5d",i); } } printf("\n"); return 0; }
相关文章推荐
- 自己整理的前端面试的东西
- 面试自己写的技能,http与https(内容整理一下)
- 整理自己认为能理解的面试题目解法
- 整理一些自己的面试中遇到的问题,不定期更新。
- java,html5+css3以及javascript面试题------自己面试的时候遇到的面试题,所以整理一下
- 线程面试问题整理
- 百度前端面试题目整理
- 面试如何回答自己的缺点
- 面试基础知识整理 —— 二叉搜索树
- map的整理——面试问题
- 记一次UE面试问题整理
- 虎牙 安卓开发面试 问题整理(2018.3.6)
- Android面试题目整理(自用)
- DateUtil 工具类整理一些自己用到过得,有点逻辑处理的方法
- 公共免费开发接口地址 ---自己整理方便使用
- git 常用命令(自己整理)
- JavaWeb面试内容整理(包含大公司的面试题)
- 面试季,如何通过衣品为自己加薪
- Mybatis 学习笔记 1(非原创 自己整理)
- 互联网工作面试资源整理