当前位置: 首页 > news >正文

大一C语言作业 12.14

1.A

A:将pa指向的元素赋值给x,即x = a[0]
B:将a数组第二个元素的值赋给x,即x = a[1]
C:将pa指向的下一个元素的值赋给x,即x = a[1]
D:将a数组第二个元素的值赋给x,即x = a[1]

2.  6 2 3 4 5 

       函数fun接受一个整型指针p和一个整数n作为参数。在函数内部,使用for循环对指针p所指向的值进行n次自增操作。在main函数中,创建了一个包含5个元素的整型数组a,并将其初始化为{1, 2, 3, 4, 5}。然后调用fun函数,将数组a和5作为参数传递给fun函数。最后,使用for循环打印数组a中的每个元素。

在fun函数中,对指针p所指向的值进行了5次自增操作,因为p指向了数组a的第一个元素,所以数组a中的第一个元素变为了6。但是,指针p没有被移动,所以对于后续的自增操作,仍然是对第一个元素进行自增。因此,数组a中的第一个元素变为了6,而其他元素没有发生变化

3.  D

A和B都是错误的,因为它们试图将一个指针的值赋给指针自己
D*p = p[0]; 这一行将指针p指向的数组的第一个元素赋给指针p所指向的变量。 

4.  5

`*p` 是指针 p 指向的元素的值。
具体来说,指针 `p` 初始化为指向数组 `a` 的第三个元素(下标为2)之后的一个位置。因此,`*p` 将会是数组 `a` 中第四个元素的值,即 5。

5.D

       在C语言中,数组名作为函数参数时,实际上是传递了该数组的地址。因此,在f()函数内部,可以通过指针来访问和修改main()函数中的数组元素。但是,这并不是双向的值传递,因为实参(即main()函数中的数组)并没有被复制到形参(即f()函数中的数组),而是传递了数组的地址。因此,任何对形参的操作都不会影响实参本身。 

 6.   0x7fffb6514a90, 0x7fffb6514a90, 0x7fffb6514a90, 0x7fffb6514aa4, 19, 1
 

a 是数组名,它代表整个数组的首地址。

&a 表示获取数组 a 的地址。由于数组名就是数组的地址,所以 &a 和 a 相同。

p 是一个指针变量,初始化为指向数组 a 的首地址。

p+9 表示将指针 p 向后移动9个元素(即增加9倍于元素类型大小的偏移量)。由于数组 a 中每个元素都是整型(int),所以在32位系统中,p+9 指向的是数组 a 中第10个元素的位置。

*p+9 表示先获取指针 p 指向的元素的值(即数组 a 中第一个元素的值),然后将其与整数9相加。因此,*p+9 等于19。

*(p+9) 表示获取指针 p+9 指向的元素的值(即数组 a 中第10个元素的值)。因此,*(p+9) 等于1。

7.

#include<stdio.h>
double Swap(double *a,double *b);
int main(){double x = 80.0,y =90.0;Swap(&x,&y);printf("x=%f,y=%f",x,y);return 0;
}
double Swap(double *a,double *b){double temp;temp = *a;*a = *b;*b = temp;
}
#include<stdio.h>
double Swap(double x,double y);
int main(){double a = 100.0,b = 200.0;Swap(a,b);printf("a=%f,b=%f",a,b);return 0;
}
double Swap(double x,double y){double temp;temp = x;x = y;y = temp;
}

8. 

#include <stdio.h>
#include <stdlib.h>void bubble_sort(float *arr, int n) {float temp;int i, j;for (i = 0; i < n - 1; i++) {for (j = 0; j < n - i - 1; j++) {if (*(arr + j) > *(arr + j + 1)) {temp = *(arr + j);*(arr + j) = *(arr + j + 1);*(arr + j + 1) = temp;}}}
}int main() {int i;float arr[5], temp;printf("Enter 5 real numbers: ");for (i = 0; i < 5; i++) {scanf("%f", &arr[i]);}bubble_sort(arr, 5);printf("Sorted numbers in descending order:\n");for (i = 0; i < 5; i++) {printf("%.2f ", arr[i]);}return 0;
}
http://www.lryc.cn/news/260092.html

相关文章:

  • 微服务技术 RabbitMQ SpringAMQP P61-P76
  • BearPi Std 板从入门到放弃 - 先天神魂篇(3)(RT-Thread I2C设备 读取光照强度BH1750)
  • 中文分词演进(查词典,hmm标注,无监督统计)新词发现
  • Docker容器数据卷
  • chatGPT 国内版,嵌入midjourney AI创作工具
  • Yum仓库架构解析与搭建实践
  • ElementPlus中的分页逻辑与实现
  • 实验01:静态路由配置实验
  • C#中简单的继承和多态
  • 15、lambda表达式、右值引用、移动语义
  • spring boot 实现直播聊天室(二)
  • alibaba fastjson GET List传参 和 接收解析
  • API自动化测试是什么?我们该如何做API自动化测试呢?
  • PyTorch 的 10 条内部用法
  • Django、Echarts异步请求、动态更新
  • Mac部署Odoo环境-Odoo本地环境部署
  • 【✅面试编程题:如何用队列实现一个栈】
  • Windows本地的RabbitMQ服务怎么在Docker for Windows的容器中使用
  • YOLOv5改进 | 2023卷积篇 | AKConv轻量级架构下的高效检测(既轻量又提点)
  • 微信小程序:模态框(弹窗)的实现
  • uniapp交互反馈api的使用示例
  • XUbuntu22.04之HDMI显示器设置竖屏(一百九十八)
  • 如何用 Cargo 管理 Rust 工程系列 甲
  • Windows下ping IP+端口的方法
  • 【python】os.getcwd()函数详解和示例
  • Linux(二十一)——virtualenv安装成功之后,依然提示未找到命令(-bash: virtualenv: 未找到命令)
  • RNN介绍及Pytorch源码解析
  • Qt 文字描边(基础篇)
  • .360勒索病毒解密方法|勒索病毒解决|勒索病毒恢复|数据库修复
  • Nginx(四层+七层代理)+Tomcat实现负载均衡、动静分离