1604期 第1期测试(面试精选:C,LINUX,数据结构部分)

本试卷从考试酷examcoo网站导出,文件格式为mht,请用WORD/WPS打开,并另存为doc/docx格式后再使用

试卷编号:241486
试卷录入者:
试卷总分:100
出卷时间:2016-05-05 17:09
答题时间:120分钟

一、单项选择题(共15题,每题2分,共30分)
1.下面关于i节点描述错误的是 [2分]
A. i节点和文件是一一对应的(每个文件都有唯一一个索引结点号与之对应,而对于一个索引结点号,却可以有多个文件名与之对应)
B. i节点能描述文件占用的块数
C. i节点描述了文件大小和指向数据块的指针
D. 通过i节点实现文件的逻辑结构和物理结构的转换
参考答案:A

2.假设目录中存在若干文件file_num.txt(num表示文件编号,1~10),使用以下哪个通配符可以只挑选出其中的编号为1、3、5的文件?[2分]
A. file_*.txt
B. flie_?.txt
C. file_[135].txt
D. file_[^135].txt
参考答案:C

3.Linux文件权限一共10位长度,分成四段,第三段表示的内容是[2分]
A. 文件类型
B. 文件所有者的权限
C. 文件所有者所在组的权限
D. 其他用户的权限
参考答案:C
-rwxrw-rw-
4.如果有定义:char **a[3][4], sizeof(a)的结果是:[2分]

这是定义一个指向char*类型的指针二维数组
32位下应该是4*3*4=48字节
A. 4
B. 12
C. 48
D. 64
参考答案:C

5.有程序如下:
int main(void)
{
unsignedchar a = 0xa5;
unsignedchar b = ~a>> 4+1;
printf("%d\n",b);
return0;
}其执行结果是[2分]
A. 245
B. 246
C. 2
D. 250
参考答案:D
因为~的优先级别高于>>,所以是先对a取反,即1010 0101----> 0101 1010
因为+的优先级别大于>>,所以是右移5位,得到:0000 0010 结果是2;
但是这确实错误的答案,在vs2008上运行的时候结果却是 250;原来这是16为寄存器,
0xA5是:0000 0000 1010 0101;取反之后变成:1111 1111 0101 1010
右移5位后得到的是:0000 0111 1111 1010;由于unsigned char型只能表示低八位,这样既得到: 250;

6.有程序如下:
int main(void) {
char *a[] = {"hello", "the", "world"};
char **pa = a; pa++; printf("%s\n",*pa);
return0;
}其执行结果是[2分]
A. theworld
B. the
C. ello
D. elloworld
参考答案:B

7.在带有头结点的单链表HL中,要向表头插入一个由指针p指向的结点,则执行( )[2分]
A. HL->next=P; P->=H->next;
B. p->next=HL; HL=p;
C. p->next=HL->next;HL->next=P
D. p->next=HL->next; p=HL;
参考答案:C

8.在32平台下,结构体data定义如下:
struct data
{
char a;
int b;
short c;
};
则其大小为[2分]
A. 8
B. 10
C. 12
D. 16
参考答案:C

9.阅读如下程序:
int a=5;
void show_val(void)
{
int b=3;
static int c=2;
a += 5;
b += 5;
c += 5;
printf("%d,%d,%d\n",a,b,c);
c = b;
}
int main(void)
{
int b=0;
static int c;
a += 3;
show_val(); // show values

b += 3;
show_val (); // show values again
return 0;
}
则其执行结果是 [2分]
A. 13,0,13
B. 18,8,13
C. 13,8,13
D. 18,8,0
参考答案:B

10.以下程序输出的结果是 ?????
int main(void){
int b = 3;
int arr[] = {6, 7, 8, 9, 10};
int *ptr = arr;
*(ptr++)+= 123;
printf("%d%d\n", *ptr, *(++ptr));
return0;
}[2分]
A. 8 8
B. 130 8
C. 7 7
D. 7 8
参考答案:A

然后int* ptr=arr;这一句使得ptr指针指向arr数组的第一个数,也就是6;
*(ptr++)+=123;这个不是先执行括号里面的,因为里面的是ptr++,这是先取值,再自加,这一句相当于*ptr+=123;ptr++;两句。实际就是使得*ptr指针的内容加上123。也就是数组第一个6加上123变成129。做完之后ptr自加。这时候ptr指针指向数组的第二个数7;
最后一个printf语句,先执行的是后面的*(++ptr)而不是*(ptr),所以ptr先自增,使得指针指向8,然后输出。这样就输出的都是8了。你可以把*(++ptr)和*(ptr)的位置对调一下,那么先执行*(ptr),再执行*(++ptr)。那么输出的就是8,7了。
不知道这么说你明白了没

11.二叉树中前序遍历的非递归算法是利用以下哪种数据结构[2分]
A. 顺序表
B. 队列
C. 栈
D. 树
参考答案:C

12.有以下代码:
void sub(int x, int y, int *z)
{
*z = y–x;
}
int main(void)
{
int a, b, c;
sub(10, 5, &a);
sub(7, a, &b);
sub(a, b, &c);
printf(“%4d,%4d,%4d\n”,a,b,c);
}
则其执行结果是[2分]
A. 5,2,3
B. -5,-12,-7
C. -5,-12,-17
D. 5,-2,-7
参考答案:B

13.有一棵二叉树如下:

用中序遍历法遍历之,则遍历的次序是[2分]
A. ABCDEFG
B. CBEGDFA
C. CBAEDGF
D. CEGDFBA
参考答案:B

14.设栈最大长度为3,入栈序列为1,2,3,4,5,6,,则不可能得出栈序列的是[2分]
A. 1,2,3,4,5,6
B. 2,1,3,4,5,6
C. 3,4,2,1,5,6
D. 4,3,2,1,5,6
参考答案:D
分析:A:可以1进栈然后1出栈,2进栈2出栈3,4,5,6,同理。
B:1进栈2进栈,然后2出栈,1出栈后面和A相同。
C:1,2,3进栈,然后3出栈4进栈,4出栈,2出栈,1出栈,5进栈5出栈,6进栈6出栈。
D:1,2,3,4都进,然后4 出栈 3出栈2出栈1出栈 但是进栈的时候已经超过最大长度了。

15.假设执行语句S的时间为O(1),则执行下列程序段的时间为
for(i=1;i<=n;i++)
for(j=i; j<=n; j++)
S;[2分]
A. O(n)
B. O(n2)
C. O(n*i)
D. O(n+1)
参考答案:B

二、填空及简答题(共10题,共34分)
1.分析sizeof的结果(在32位平台下)
int a[10] = {0};
sizeof(int) = 4
sizeof(char*) = 4
sizeof(char**) = 4
sizeof(a) = 40
sizeof(a[0]) = 4 [每空1分]

2.一个线性表为B=(12,23,45,57,20,03,78,31,15,36),设散列表为HT[0..12],散列函数为H(key)= key % 13并用线性探查法解决冲突,请画出散列表(空单元用‘#’代表)[3分]

参考答案:

78 15 03 57 45 20 31 23 36 12

3.请举出const关键字在C语言中的三种用途。[3分]

const int Max=100; int Array[Max];
void f(const int i)
可以节省空间,避免不必要的内存分配。 例如:
#define PI 3.14159 //常量宏
const doulbe Pi=3.14159; //此时并未将Pi放入ROM中 ......
double i=Pi; //此时为Pi分配内存,以后不再分配!
double I=PI; //编译期间进行宏替换,分配内存
double j=Pi; //没有内存分配
double J=PI; //再进行宏替换,又一次分配内存!

4..写出在双向循环链表中,在指针p指向的节点之前插入一个q节点的算法。[3分]

参考答案:
q->prior=p->prior;
(p->prior)->next=q;
q->next=p;
p->prior=q;

5.Typedef 在C语言中频繁用以声明一个已经存在的数据类型的同义字。也可以用预处理器做类似的事。例如,思考一下下面的例子:
#define dPS struct s *
typedef struct s * tPS;
以上两种情况的意图都是要定义dPS 和 tPS 作为一个指向结构s指针。哪种方法更好呢?(如果有的话)为什么?[3分]

dPS p1,p2;
tPS p3,p4;
第一个扩展为
struct s * p1, p2;
上面的代码定义p1为一个指向结构的指,p2为一个实际的结构,这也许不是你想要的。第二个例子正确地定义了p3 和p4 两个指针。
参考答案
6.全局变量可不可以定义在可被多个.c文件文件包含的头文件中?为什么?[4分]

参考答案:肯定可以了,只要头文件不要被重复定义

7.static全局变量与普通的全局变量有什么区别?static局部变量和普通局部变量有什么区别?static函数与普通函数有什么区别?[3分]
文件内使用static全局变量,整个程序中可以用
Static局部变量作用域在函数内,但模块结束值不变,局部变量模块结束值释放
函数的定义和声明默认情况下是extern的,但静态函数只是在声明他的文件当中可见,不能被其他文件所用。
参考答案:

8.队列和栈有什么区别?[3分]

参考答案:
栈和队列是在程序设计中被广泛使用的两种线性数据结构,它们的特点在于基本操作的特殊性,栈必须按"后进先出"的规则进行操作,而队列必须按"先进先出"的规则进行操作。和线性表相比,它们的插入和删除操作受更多的约束和限定,故又称为限定性的线性表结构。

9.请定义一个宏,比较两个数a、b的大小,不能使用大于、小于、if语句[4分]

参考答案:#define MAX (a>b):a?b

10.如何输出源文件的文件名和目前执行行的行数?[3分]

参考答案:
printf("the file name: %s\n",__FILE__);
printf("the file name: %d\n",__LINE__);

三、请指出以下程序片段的不妥之处。(共4题,共16分)
1.程序片段一:
void GetMemory(char *p, int nNum)
{
p = (char *)malloc(sizeof(char) * nNum);
}
void Test(void)
{
char *str = NULL;
GetMemory(str, 100);
strcpy(str, "hello"); //rodata数据区不能改变值
}[4分]

参考答案:
值传递不能改变str的值,,所以实参str的值仍然为NULL,不能进行引用

2.下面的代码会在哪一行崩溃,为什么?
struct s
{
inti;
int*p;
};
int main(void)
{
structS s;
int*p = &s.i;
p[0]= 4;
p[1]= 3;
s.p= p;
s.p[1]= 1;
s.p[0]= 2;
return0;
}[4分]

参考答案:
s.p 和s.p[1]指向同一个地方,s.p[1] = 1就让s.p指向内存地址为1的位置,s.p[0]=2相当于*((int*) 1)=2;

3.下面的代码片段的输出是什么,为什么?
char *ptr;
if ((ptr = (char *)malloc(0)) == NULL)
puts("Got a null pointer");
else
puts("Got a valid pointer");[4分]

参考答案:
Got a valid pointer,malloc申请失败时,返回NULL,否则返回申请到的起始地址。

4.int main(void)
{
int a[5]={1,2,3,4,5};
int *ptr =(int *)(&a +1);
pinrtf(“%d,%d”,*(a+1),*(ptr-1));
}输出是什么,请简要说明原因[4分]

参考答案:*(a+1) = 2,*(ptr-1)= 5;
&a+1是在a指针的地址+1得到的是即a[4]后面的一个地址

四、编程题(共3题,共20分)
1.将一句话中的单词倒置,标点符号不用倒换,例如”I come from Tianjin!”倒换之后变成“Tianjin ! from come I”[7分]

参考答案:
#include<stdio.h>
#include<string.h>

void change(char *s);
reverse(char *s,int start,int end);

void main()
{
char s[50];
printf("请输入字符串\n");
gets(s);
change(s);
printf("到之后的字符串为%s\n",s);
}

void change(char *s)
{
int len,start,end,i;
len = strlen(s);
start = 0;
end = len-1;
reverse(s,start,end);
end = 0;
for(i = 0;i < len;)
{
if(s[i] != ' ')
{
start = i;
while(s[i] != ' ' && s[i] != '\0')
i++;

end = i-1;
reverse(s,start,end);;
}
i++;
}

}

reverse(char *s,int start,int end)
{
char temp;
while(start < end)
{
temp = s[start];
s[start] = s[end];
s[end] = temp;
start++;
end--;
}
}

2.编写程序把字符串转换成整型数 如:int atoi( const char * str)[6分]

int StrToInt(const char* str)
{
g_nStatus = kInvalid;
long long num = 0;
if(str != NULL)//至少保证字符串不为空
{
const char* digit = str;//用了一下中间变量,保存原始字符串,防止被破坏
// the first char in the string maybe '+' or '-'
bool minus = false;
if(*digit == '+')//通过第一个字符判断是正是负
digit ++;
else if(*digit == '-')
{
digit ++;
minus = true;
}
// the remaining chars in the string
while(*digit != '\0')//字符串结束标志
{
if(*digit >= '0' && *digit <= '9')
{
num = num * 10 + (*digit - '0');
// overflow
if(num > std::numeric_limits::max())//整数溢出的情况
{
num = 0;
break;
}
digit ++;
}
// if the char is not a digit, invalid input
else
{
num = 0;
break;
}
}
if(*digit == '\0')
{
g_nStatus = kValid;
if(minus)
num = 0 - num;//转化为负数的方式
}
}
return static_cast(num);
}
3.编写一个函数bubble_sort(),用冒泡法将数组int a[] = {49, 38, 65, 97, 76, 13, 27} 按升序排序。[7分]

参考答案:

#define SIZE 7

void show(int num[])
{
int i;
printf("\t");
for(i=SIZE; i>0; --i)
{
printf("%4d", num[SIZE-i]);
} printf("\n");
return;
}
void bubble_sort(int num[])
{
int i, j;
for(i=SIZE; i>0; --i)
{
int flag = 0;
for(j=0; j<i-1; j++)
{
int tmp;
if(num[j] > num[j+1])
{
tmp = num[j];
num[j] = num[j+1];
num[j+1] = tmp;
flag = 1;
}
}
show(num);
if(flag == 0) //nerver been changed
break;
}
return;
}
int main(void)
{
/* original data */
int array[SIZE] = {49, 38, 65, 97, 76, 13, 27};
printf("the original numbers are:\n");
show(array); /* bubble sorting */
printf("steps of bubble sorting:\n");
bubble_sort(array);
return 0;
}

≡ 本试卷共计32题,此处为结束标志。
≡ examcoo™

C,LINUX,数据结构部分的更多相关文章

  1. Linux数据包路由原理、Iptables/netfilter入门学习

    相关学习资料 https://www.frozentux.net/iptables-tutorial/cn/iptables-tutorial-cn-1.1.19.html http://zh.wik ...

  2. 配置Linux数据转发(给其他接口转发一个接口的internet网络)

    配置Linux数据转发 [主机]第一步开启转发net.ipv4.ip_forward = 1echo "1" > /proc/sys/net/ipv4/ip_forward第 ...

  3. Linux数据备份与恢复

    Linux数据备份及服务器重要数据类别分析 对 Linux 服务器来讲,当然最理想的就是把整块硬盘中的数据都备份,甚至连分区和文件系统都备份,这样如果硬盘损坏,那么我们可以直接把备份硬盘中的数据导入损 ...

  4. 11款最棒的Linux数据恢复工具

    无论你使用的是台式电脑还是笔记本,需要关注的重点之一都是如何保护好你的宝贵数据.因为总会有各种突发情况使你的系统崩溃,然后你要做的就是恢复数据.不管你怎么想,要是我失去了所有的数据却无法恢复的话,我会 ...

  5. Linux数据归档和解压缩tar,cpio,gzip,bzip,lzma,zip命令使用

    转载:http://www.1987.name/659.html 数据压缩归档和备份是系统管理的日常工作,定期备份不可小视,归档和压缩对于系统管理员或是普通用户来说都经常用到的操作,有很多中压缩格式, ...

  6. Linux数据写操作改进

    Linux的IO操作中数据的写函数int nwrite = write(int fd,void* buf ,int len)表示向fd文件描述符写入len个字节长度的数据报文,但是这并不能保证真正向内 ...

  7. linux数据盘分区以及格式化

    首先切换到root账户下  sudo -i 手动格式化 请根据以下步骤对数据盘进行分区以及格式化,并挂载分区使数据盘可用. 注:执行以下命令时,请注意修改数据盘符,可以使用”fdisk -l”查看盘符 ...

  8. linux 数据盘和系统盘的查看

    系统盘就像linux的c盘,使用df -l命令查看 如下所示: 可以看到根路径 / 都是位于系统盘.而/root,/home,/usr就如同c盘下的c:\windows,c:\usr这些目录 如果单独 ...

  9. Linux数据备份与恢复 dump、restore、dd命令

    dump命令:备份分区.文件或目录 在Linux系统中 dump 命令是没有安装的,所以先安装一下 dump 命令,安装命令如下: [root@localhost -]# yum -y install ...

随机推荐

  1. JAVA线程同步 (二)notify()与notifyAll()-***

    编写多线程程序需要进行线程协作,前面介绍的利用互斥来防止线程竞速是来解决线程协作的衍生危害的.编写线程协作程序的关键是解决线程之间的协调问题,在这些任务中,某些可以并行执行,但是某些步骤需要所有的任务 ...

  2. JS复制文件(转)

    <script type="text/javascript"> var fso, f; function copyFile() { fso = new ActiveXO ...

  3. linux编译安装gcc5.3.0

    1.下载GCC5.3.0安装包 #su #cd /opt #wget http://ftp.gnu.org/gnu/gcc/gcc-5.3.0/gcc-5.3.0.tar.gz 2.解压 #.tar. ...

  4. 01背包(类) UVA 10564 Paths through the Hourglass

    题目传送门 /* 01背包(类):dp[i][j][k] 表示从(i, j)出发的和为k的方案数,那么cnt = sum (dp[1][i][s]) 状态转移方程:dp[i][j][k] = dp[i ...

  5. 数学 FZU 2074 Number of methods

    题目传送门 /* 数学:假设取了第i个,有C(n-1)(i-1)种取法 则ans = sum (C(n-1)(i-1)) (1<i<=n) 即2^(n-1) */ #include < ...

  6. 编写UI自动化测试用例原则

    1.一个脚本是一个完整的场景,从用户登陆操作到用户退出系统关闭浏览器.2.一个脚本脚本只验证一个功能点,不要试图用户登陆系统后把所有的功能都进行验证再退出系统3.尽量只做功能中正向逻辑的验证,不要考虑 ...

  7. iOS popViewControllerAnimated后刷新原先的表格

    当主页面列表push子页面,子页面修改后pop回主页面后应该刷新主页面列表数据,不修改子页面信息就不刷新主页面列表,这里介绍个取巧的方法:利用[NSNotificationCenter default ...

  8. 卸载掉原有mysql

    [root@xiaoluo ~]# rpm -qa | grep mysql // 这个命令就会查看该操作系统上是否已经安装了mysql数据库 有的话,我们就通过 rpm -e 命令 或者 rpm - ...

  9. 判断IE浏览器的类型以及提示信息(低版本浏览器不予显示)

    //浏览器IE版本判断(function(window) {    var theUA = window.navigator.userAgent.toLowerCase();    if ((theU ...

  10. JavaScript(第二部分)

    一.DOM获取元素节点的子节点  1.getElementsByTagName() 返回当前节点的指定标签名子节点 2.childNodes     表示当前节点的所有子节点 3.firstChild ...