C++ 学习第八天 一维数组实战

本文通过三个案例展示了数组在C++中的应用:统计数组长度和首地址、数组元素逆置以及冒泡排序。案例详细解释了如何找出数组中最大值、如何实现数组元素的反转以及冒泡排序的完整过程,提供了具体的代码实现。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一维数组名称的用途:

1. 可以统计整个数组在内存中的长度
2. 可以获取数组在内存中的首地址

注意:数组名是常量,不可以赋值

总结1:直接打印数组名,可以查看数组所占内存的首地址

总结2:对数组名进行sizeof,可以获取整个数组占内存空间的大小

数组中元素的个数=sizeof(数组)/sizeof(数组[0]);

在一个数组中记录了五只小猪的体重,如:int arr[5] = {300,350,200,400,250};

找出并打印最重的大猪体重。
#include<iostream>

using namespace std;

int main()
{
    int arr[5] = { 300,350,200,400,250 };
    int max = 0;

    for (int i = 0; i < 5; i++)
    {
        if (arr[i] > max)
        {
            max = arr[i];
        }
    }
    cout << "最重的猪是:" << max << endl;
    system("pause");
    return 0;
}

案例2:请声明一个5个元素的数组,并且将元素逆置.

#include<iostream>
using namespace std;

int main()
{
	int start = 0;
	int arr[] = { 1,3,2,5,4 };
	int end = sizeof(arr) / sizeof(arr[0]) - 1;
	int temp = 0;
	if (start < end)
	{
		temp = arr[start];
		arr[start] = arr[end];
		arr[end] = temp;
		start++; end--;
	}
	cout << "逆置后 的数组" << endl;
	for (int i = 0; i < 5; i++)
	{
		cout << arr[i];
	}
	system("pause");
	return 0;
}

案例3:冒泡排序

1. 比较相邻的元素。如果第一个比第二个大,就交换他们两个。
2. 对每一对相邻元素做同样的工作,执行完毕后,找到第一个最大值。
3. 重复以上的步骤,每次比较次数-1,直到不需要比较
4.总的排序轮数=元素个数-1
5.每轮对比的次数=元素个数-排序轮数-1

int main() {

	int arr[9] = { 4,2,8,0,5,7,1,3,9 };

	for (int i = 0; i < 9 - 1; i++)
	{
		for (int j = 0; j < 9 - 1 - i; j++)
		{
			if (arr[j] > arr[j + 1])
			{
				int temp = arr[j];
				arr[j] = arr[j + 1];
				arr[j + 1] = temp;
			}
		}
	}

	for (int i = 0; i < 9; i++)
	{
		cout << arr[i] << endl;
	}
    
	system("pause");

	return 0;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值