2.使用指针法输出数组元素值
时间: 2023-05-19 07:07:04 浏览: 57
可以使用以下代码来使用指针法输出数组元素值:
```c
#include <stdio.h>
int main() {
int arr[] = {1, 2, 3, 4, 5};
int *ptr = arr;
for (int i = 0; i < 5; i++) {
printf("%d ", *(ptr + i));
}
return 0;
}
```
这段代码中,我们定义了一个整型数组 `arr`,并将其首地址赋值给指针 `ptr`。然后,我们使用指针法遍历数组,并使用 `printf` 函数输出每个元素的值。
相关问题
简单的整型数组操作:构造一个包含n个元素的一维整型随机数组(0≤n≤100) ,其中无重复元素。完成表10-1的操作。 1. 使用下标法输出数组元素值 2. 使用指针法输出数组元素值 3. 对数组中所有偶数求和 4. 对数组中所有奇数求和 5. 将数组中的所有数扩大k倍 6. 把数组中所有偶数位置的元素加起来 7. 找出数组中的最大值 8. 找出数组中的最小值 9. n在数组中搜索指定元素,看其是否存在
答案:
1.构造随机数组:
#include <stdio.h>
#include <stdlib.h>
#include <time.h>
int main()
{
int n, i, j, temp, flag;
int arr[100];
srand((int)time(NULL)); //用系统时间初始化rand()函数
printf("请输入n的值:");
scanf("%d", &n);
for (i = 0; i < n; i++) {
flag = 1;
temp = rand() % 100 + 1; //生成1-100内的随机数
for (j = 0; j < i; j++) {
if (arr[j] == temp) { //如果与已生成的元素重复,重新生成
flag = 0;
break;
}
}
if (flag) {
arr[i] = temp;
}
else {
i--;
}
}
printf("生成的随机数组为:\n");
for (i = 0; i < n; i++) {
printf("%d ", arr[i]);
}
printf("\n");
return 0;
}
2.使用指针法输出数组元素值:
#include <stdio.h>
int main()
{
int arr[] = {1, 2, 3, 4, 5};
int* p;
for (p = arr; p < arr + 5; p++) {
printf("%d ", *p);
}
printf("\n");
return 0;
}
3.对数组中所有偶数求和:
#include <stdio.h>
int main()
{
int arr[] = {1, 2, 3, 4, 5};
int n = sizeof(arr) / sizeof(arr[0]);
int i, sum = 0;
for (i = 0; i < n; i++) {
if (arr[i] % 2 == 0) {
sum += arr[i];
}
}
printf("所有偶数的和为%d\n", sum);
return 0;
}
4.对数组中所有奇数求和:
#include <stdio.h>
int main()
{
int arr[] = {1, 2, 3, 4, 5};
int n = sizeof(arr) / sizeof(arr[0]);
int i, sum = 0;
for (i = 0; i < n; i++) {
if (arr[i] % 2 == 1) {
sum += arr[i];
}
}
printf("所有奇数的和为%d\n", sum);
return 0;
}
5.将数组中的所有数扩大k倍:
#include <stdio.h>
int main()
{
int arr[] = {1, 2, 3, 4, 5};
int n = sizeof(arr) / sizeof(arr[0]);
int i, k;
printf("请输入k的值:");
scanf("%d", &k);
for (i = 0; i < n; i++) {
arr[i] *= k;
}
printf("扩大%d倍后的数组为:\n", k);
for (i = 0; i < n; i++) {
printf("%d ", arr[i]);
}
printf("\n");
return 0;
}
6.把数组中所有偶数位置的元素加起来:
#include <stdio.h>
int main()
{
int arr[] = {1, 2, 3, 4, 5};
int n = sizeof(arr) / sizeof(arr[0]);
int i, sum = 0;
for (i = 0; i < n; i += 2) {
if (arr[i] % 2 == 0) {
sum += arr[i];
}
}
printf("偶数位置的元素加起来为%d\n", sum);
return 0;
}
7.找出数组中的最大值:
#include <stdio.h>
int main()
{
int arr[] = {1, 2, 3, 4, 5};
int n = sizeof(arr) / sizeof(arr[0]);
int i, max = arr[0];
for (i = 1; i < n; i++) {
if (arr[i] > max) {
max = arr[i];
}
}
printf("数组中的最大值为%d\n", max);
return 0;
}
8.找出数组中的最小值:
#include <stdio.h>
int main()
{
int arr[] = {1, 2, 3, 4, 5};
int n = sizeof(arr) / sizeof(arr[0]);
int i, min = arr[0];
for (i = 1; i < n; i++) {
if (arr[i] < min) {
min = arr[i];
}
}
printf("数组中的最小值为%d\n", min);
return 0;
}
9.n在数组中搜索指定元素,看其是否存在:
#include <stdio.h>
int main()
{
int arr[] = {1, 2, 3, 4, 5};
int n = sizeof(arr) / sizeof(arr[0]);
int i, x;
printf("请输入要搜索的元素:");
scanf("%d", &x);
for (i = 0; i < n; i++) {
if (arr[i] == x) {
printf("%d存在于数组中\n", x);
return 0;
}
}
printf("%d不存在于数组中\n", x);
return 0;
}
利用指针法输入输出数组元素
利用指针法输入输出数组元素,可以通过以下步骤实现:
1. 定义一个指向数组的指针变量。
2. 通过指针变量遍历数组,逐个访问数组元素。
3. 对每个数组元素进行读写操作。
下面是一个简单的例子,演示了如何通过指针法输入输出数组元素:
```
#include <stdio.h>
int main() {
int arr;
int i;
// 输入数组元素
printf("Enter array elements:\n");
for (i = 0; i < 5; i++) {
scanf("%d", arr + i);
}
// 输出数组元素
printf("Array elements are:\n");
for (i = 0; i < 5; i++) {
printf("%d ", *(arr + i));
}
return 0;
}
```
在这个例子中,我们定义了一个包含 5 个整数的数组 `arr`,然后通过 `scanf` 函数和指针 `arr + i` 输入每个数组元素。在输出数组元素时,我们使用了指针 `arr + i` 和解引用运算符 `*`,访问每个数组元素并输出它们的值。
相关推荐
![-](https://csdnimg.cn/download_wenku/file_type_column_c1.png)
![-](https://csdnimg.cn/download_wenku/file_type_column_c1.png)
![-](https://csdnimg.cn/download_wenku/file_type_column_c1.png)
![-](https://csdnimg.cn/download_wenku/file_type_column_c1.png)
![-](https://csdnimg.cn/download_wenku/file_type_column_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)