#include <stdio.h> void swap( int *pl,int *p2) { int p; p=*pl; *p1=*p2; *p2=p; } void main() { int a,b; scanf(" %d%d ",&a, &b);
时间: 2023-08-07 13:08:27 浏览: 80
这段代码存在几个问题:
1. 函数 swap 的参数名应该是 p1 和 p2,而非 pl 和 p2。
2. 函数 swap 中的变量名 p 和参数名 p2 重复。
3. 函数 swap 中交换两个变量的语句有误,应该是 *p1 = *p2; *p2 = p;。
4. 函数 main 中没有调用 swap 函数。
5. scanf 函数中的格式化字符串多了一个空格,应该改为 scanf("%d%d", &a, &b);。
修正后的代码如下:
```c
#include <stdio.h>
void swap(int *p1, int *p2) {
int tmp = *p1;
*p1 = *p2;
*p2 = tmp;
}
int main() {
int a, b;
scanf("%d%d", &a, &b);
swap(&a, &b);
printf("a = %d, b = %d\n", a, b);
return 0;
}
```
输入例如:
```
1 2
```
输出结果为:
```
a = 2, b = 1
```
相关问题
#include<stdio.h> void swap(int *p1.int *p2) { int *p; p=p1; p1=p2; p2=p; } int main() { int a,b,*pt1,*pt2; scanf("%d,%d",&a,&b); pt1=&a; pt2=&b; if(a<b) swap(pt1;pt2); printf("%d,%d\n",*pt1,*pt2); return 0; }找出错误并修改
有两处错误:
1. 函数 `swap` 的参数类型应该是 `int *p1, int *p2`,而不是 `int *p1.int *p2`。
2. 函数 `swap` 中交换指针指向的值的语句应该是 `int temp = *p1; *p1 = *p2; *p2 = temp;`,而不是 `p=p1; p1=p2; p2=p;`。
修改后的代码如下:
```c
#include <stdio.h>
void swap(int *p1, int *p2) {
int temp = *p1;
*p1 = *p2;
*p2 = temp;
}
int main() {
int a, b, *pt1, *pt2;
scanf("%d,%d", &a, &b);
pt1 = &a;
pt2 = &b;
if (a < b) {
swap(pt1, pt2);
}
printf("%d,%d\n", *pt1, *pt2);
return 0;
}
```
#include<stdio.h> int main(void) { int *p; *p=5; printf("%d",*p) }这串代码有什么问题
这段代码有指针未初始化的问题,指针变量 `p` 没有被赋值任何地址,因此在赋值 `*p=5` 时,程序会试图向未知的内存地址写入数据,这可能导致程序崩溃或者其他不可预知的错误。应该先为指针变量分配空间或者将其指向已经存在的变量地址,例如:
```c
#include <stdio.h>
int main(void) {
int a = 5;
int *p = &a; // p 指向变量 a 的地址
printf("%d", *p); // 输出 p 所指向的变量的值,即 a 的值 5
return 0;
}
```