CC++面试题目汇总(8)

2019-08-02 00:18

bit.c=15; pri

改错:

#include

int main(void) { int **p; int arr[100];

p = &arr; return 0; }

解答:

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

&arr; //得到的是指向第一维为100的数组的指针 #include 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(\%d\\n\sizeof(s1)); printf(\2)= %d\\n\sizeof(s2)); 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。 望高手赐教!!

第一题,注意可增长数组的应用. #include #include

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(\2\ exit(-1); }

int i = 0; int j = 0;

while(fscanf(fp1,\!= EOF) { 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; }

第二题.

#include

int main(void) {

unsigned long int i,j,k;

printf(\input the number\\n\scanf(\ if( i % 2 == 0) j = i / 2; else

j = i / 2 + 1;

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

printf(\= %d + %d\\n\- k); return 0; }

#include 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(\%d, %d\}

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


CC++面试题目汇总(8).doc 将本文的Word文档下载到电脑 下载失败或者文档不完整,请联系客服人员解决!

下一篇:[参考文档]旅游管理毕业论文参考文献word版本(3页)

相关阅读
本类排行
× 注册会员免费下载(下载后可以自由复制和排版)

马上注册会员

注:下载文档有可能“只有目录或者内容不全”等情况,请下载之前注意辨别,如果您已付费且无法下载或内容有问题,请联系我们协助你处理。
微信: QQ: