教学文库网 - 权威文档分享云平台
您的当前位置:首页 > 精品文档 > 高等教育 >

C&C++面试题汇总(7)

来源:网络收集 时间:2026-04-11
导读: int main(void) { int **p; int arr[100]; p = return 0; } 解答: 搞错了,是指针类型不同, int **p; //二级指针 //得到的是指向第一维为100的数组的指针 #i nclude int main(void) { int **p, *q; int arr[100];

int main(void) { int **p; int arr[100]; p = &arr; return 0; } 解答:

搞错了,是指针类型不同, int **p; //二级指针

&arr; //得到的是指向第一维为100的数组的指针 #i nclude int main(void) { int **p, *q; int arr[100]; q = arr; p = &q; return 0; }

下面这个程序执行后会有什么错误或者效果: #define MAX 255 int main() {

unsigned char A[MAX],i;//i被定义为unsigned char for (i=0;i<=MAX;i++) A[i]=i; }

解答:死循环加数组越界访问(C/C++不进行数组越界检查) MAX=255

数组A的下标范围为:0..MAX-1,这是其一.. 其二.当i循环到255时,循环内执行: A[255]=255;

这句本身没有问题..但是返回for (i=0;i<=MAX;i++)语句时,

由于unsigned char的取值范围在(0..255),i++以后i又为0了..无限循环下去. struct name1{ char str; short x; int num; }

struct name2{ char str; int num; short x; }

sizeof(struct name1)=8,sizeof(struct name2)=12

在第二个结构中,为保证num按四个字节对齐,char后必须留出3字节的空间;同时为保证整个结构的自然对齐(这里是4字节对齐),在x后还要补齐2个字节,这样就是12字节。 intel:

A.c 和B.c两个c文件中使用了两个相同名字的static变量,编译的时候会不会有问题?这两个static变量会保存到哪里(栈还是堆或者其他的)?

static的全局变量,表明这个变量仅在本模块中有意义,不会影响其他模块。 他们都放在数据区,但是编译器对他们的命名是不同的。

如果要使变量在其他模块也有意义的话,需要使用extern关键字。 struct s1 {

int i: 8; int j: 4; int a: 3; double b; }; struct s2 {

int i: 8; int j: 4; double b; int a:3; };

printf(\printf(\result: 16, 24 第一个struct s1 {

int i: 8; int j: 4; int a: 3; double b; };

理论上是这样的,首先是i在相对0的位置,占8位一个字节,然后,j就在相对一个字节的位置,由于一个位置的字节数是4位的倍数,因此不用对齐,就放在那里了,然后是a,要在3位的倍数关系的位置

上,因此要移一位,在15位的位置上放下,目前总共是18位,折算过来是2字节2位的样子,由于double是8字节的,因此要在相对0要是8个字节的位置上放下,因此从18位开始到8个字节之间的位置被忽略,直接放在8字节的位置了,因此,总共是16字节。

第二个最后会对照是不是结构体内最大数据的倍数,不是的话,会补成是最大数据的倍数上面是基本问题,接下来是编程问题:

本人很弱,这几个题也搞不定,特来求救: 1)读文件file1.txt的内容(例如): 12 34 56

输出到file2.txt: 56 34 12 (逆序)

2)输出和为一个给定整数的所有组合 例如n=5

5=1+4;5=2+3(相加的数不能重复) 则输出 1,4;2,3。 望高手赐教!!

第一题,注意可增长数组的应用. #i nclude #i nclude int main(void) {

int MAX = 10;

int *a = (int *)malloc(MAX * sizeof(int)); int *b; FILE *fp1; FILE *fp2;

fp1 = fopen(\if(fp1 == NULL) {printf(\ exit(-1); }

fp2 = fopen(\

if(fp2 == NULL) {printf(\ exit(-1); }

int i = 0; int j = 0;

while(fscanf(fp1,\{ i++; j++;

if(i >= MAX) {

MAX = 2 * MAX;

b = (int*)realloc(a,MAX * sizeof(int)); if(b == NULL) {

printf(\exit(-1); } a = b; } }

for(;--j >= 0;)

fprintf(fp2,\fclose(fp1); fclose(fp2); return 0; } 第二题.

#i nclude int main(void) {

unsigned long int i,j,k;

printf(\scanf(\

if( i % 2 == 0) j = i / 2; else

j = i / 2 + 1;

printf(\ for(k = 0; k < j; k++)

printf(\return 0; }

#i nclude void main() {

unsigned long int a,i=1; scanf(\if(a%2==0) {

for(i=1;i

for(i=1;i<=a/2;i++)

printf(\}

兄弟,这样的题目若是做不出来实在是有些不应该, 给你一个递规反向输出字符串的例子,可谓是反序的经典例程.

void inverse(char *p) {

if( *p = = '\\0' ) return;

inverse( p+1 ); printf( \}

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

inverse(\ return 0; }

借签了楼上的“递规反向输出”

…… 此处隐藏:622字,全部文档内容请下载后查看。喜欢就下载吧 ……
C&C++面试题汇总(7).doc 将本文的Word文档下载到电脑,方便复制、编辑、收藏和打印
本文链接:https://www.jiaowen.net/wendang/608131.html(转载请注明文章来源)
Copyright © 2020-2025 教文网 版权所有
声明 :本网站尊重并保护知识产权,根据《信息网络传播权保护条例》,如果我们转载的作品侵犯了您的权利,请在一个月内通知我们,我们会及时删除。
客服QQ:78024566 邮箱:78024566@qq.com
苏ICP备19068818号-2
Top
× 游客快捷下载通道(下载后可以自由复制和排版)
VIP包月下载
特价:29 元/月 原价:99元
低至 0.3 元/份 每月下载150
全站内容免费自由复制
VIP包月下载
特价:29 元/月 原价:99元
低至 0.3 元/份 每月下载150
全站内容免费自由复制
注:下载文档有可能出现无法下载或内容有问题,请联系客服协助您处理。
× 常见问题(客服时间:周一到周五 9:30-18:00)