改正#include <stdio.h> #include <string.h> /*包含字符串库函数说明的头文件 * / # include <stdio.h> void forward_and_backwards(char line_of_char[] /* 函数声明 ,int index); * / void main() { char line_of_char[80]; / *定义字符数组* / int index = 0; s t r c p y ( l i n e _ o f _ c h a r ,"This is a string."); / *字符串拷贝* / f o r w a r d _ a n d _ b a c k w a r d s ( l i n e _ o f _ c h a r ,i n d e x ) ; / *函数调用* / } void forward_and_backwards(char line_of_char[] ,int index) /*函数定义* / { if (line_of_char[index]) { p r i n t f ( " % c " ,l i n e _ o f _ c h a r [ i n d e x ] ) ; / *输出字符* / f o r w a r d _ a n d _ b a c k w a r d s ( l i n e _ o f _ c h a r ,i n d e x + 1 ) ; / *递归调用* / p r i n t f ( " % c " ,l i n e _ o f _ c h a r [ i n d e x ] ) ; / *输出字符* / } }
时间: 2024-03-02 21:52:20 浏览: 55
这段代码有两个问题:
1. 函数声明和函数定义中的参数列表不一致,需要将函数声明和函数定义中的参数列表统一起来。
2. 在函数调用中,参数 index 没有初始化,会导致程序运行时出现未定义的行为,需要将 index 初始化为 0。
下面是修改后的代码:
```
#include <stdio.h>
#include <string.h>
void forward_and_backwards(char line_of_char[], int index);
int main() {
char line_of_char[80];
int index = 0;
strcpy(line_of_char, "This is a string.");
forward_and_backwards(line_of_char, index);
return 0;
}
void forward_and_backwards(char line_of_char[], int index) {
if (line_of_char[index]) {
printf("%c", line_of_char[index]);
forward_and_backwards(line_of_char, index + 1);
printf("%c", line_of_char[index]);
}
}
```
在这个修改后的代码中,我们将函数声明和函数定义中的参数列表统一起来,同时在主函数中将 index 初始化为 0。这个修改后的代码可以正确输出字符串的正反序。
阅读全文