电子科大2012届保研复试C语言程序设计试题
5星 · 超过95%的资源 | 下载需积分: 15 | DOC格式 | 49KB |
更新于2024-09-13
| 135 浏览量 | 举报
"电子科大计算机学院2012届保研复试,涉及C语言的程序设计考试,包括程序改错、简答题和编程题。考试重点在于理解C语言的基本概念,如内存管理、指针操作、数组处理及函数调用等。"
一、程序改错
1. 在给定的`StrSwap`函数中,交换两个字符数组的内容存在问题。函数试图通过交换指向字符串的指针来实现交换,但实际并未完成数据交换,因为字符数组的拷贝并未完成。正确的实现应使用临时指针存储其中一个数组的首地址,然后通过指针交换数据,如下所示:
```c
void StrSwap(char* pa, char* pb) {
char* temp = pa;
strcpy(temp, pb);
strcpy(pb, pa);
strcpy(pa, temp);
}
```
2. 程序段尝试修改字符常量,这是不允许的。在C语言中,字符常量是不可变的。`b`指向的是字符常量"House",而`a`则指向一个可修改的字符数组。因此,`b[2] = 'r'`是非法的,应当删除这一行。同时,`a=b;`这行代码会使得`a`也指向字符常量,不应出现在这里,也应该删除。
二、简答题
1. 给定的搜索数组元素的程序可能会导致数组下标越界的异常结果。在`for`循环中,当`numb`减到负数时,`arr[numb]`会访问数组的非法位置。应将`for`循环条件改为`numb < numb`,确保在数组范围内搜索。
2. 在内存布局方面:
- `int k`是全局未初始化的变量,存储在数据段的.bss段。
- `main`函数中的局部变量`p`, `q`, `ch`, 和 `k`存储在栈上,`p`指向常量区的"hello",`q`存储一个字符数组副本,`ch`和`k`各自占2个字节。
- `func`函数中的`int n`和参数`int m`也在栈上,`int m`是函数调用时传递的参数,来自`main`函数的`k`。
3. 调用函数时的不同情况:
- 当实参和形参都是数组元素时,实际上传递的是数组的首地址,即指针。
- 形参是指针时,形参接收实参提供的地址,进行间接访问。
- 实参和形参都是数组时,同样传递数组的首地址,即都是指针调用。
三、编程题
1. 编写一个逆序字符串的函数可以使用双指针法,如下所示:
```c
#include "stdio.h"
#include "string.h"
void reverse(char str[]) {
int start = 0, end = strlen(str) - 1;
while (start < end) {
char temp = str[start];
str[start] = str[end];
str[end] = temp;
start++;
end--;
}
}
int main() {
char str[] = "example";
reverse(str);
printf("Reversed string: %s\n", str);
return 0;
}
```
这个`reverse`函数通过设置两个指针,一个从字符串开头,一个从末尾,然后交换它们指向的字符,直到两个指针相遇,实现字符串的逆序排列。
相关推荐