-
一维数组`
所谓数组,就是一个集合,里面存放了相同类型的数据元素 特点一:数组中的每个数据元素都是相同的数据类型 特点二:数组是由连续的内存位置组成的 数组定义的三种方式 1.数据类型 数组名[ 数组长度 ]; 2.数据类型 数组名[ 数组长度 ] = {值1,值2,值3.....}; 3.数据类型 数组名[] = {值1 ,值2....}
#include <iostream>
using namespace std;
int main()
{
//所谓数组,就是一个集合,里面存放了相同类型的数据元素
//特点一:数组中的每个数据元素都是相同的数据类型
//特点二:数组是由连续的内存位置组成的
/*数组定义的三种方式
1.数据类型 数组名[ 数组长度 ];
2.数据类型 数组名[ 数组长度 ] = {值1,值2,值3.....};
3.数据类型 数组名[] = {值1 ,值2....}*/
//1.数据类型 数组名[ 数组长度 ];
/*int arr[5];
//为数组中的元素进行赋值
//数组元素下标是从0开始索引的
arr[0] = 10;
arr[1] = 20;
arr[2] = 30;
arr[3] = 40;
arr[4] = 50;
//访问数据元素
cout << arr[0] << endl;
cout << arr[1] << endl;
cout << arr[2] << endl;
cout << arr[3] << endl;
cout << arr[4] << endl;
//2.数据类型 数组名[ 数组长度 ] = {值1,值2,值3....}
int arr2[5] = { 10,20,30,40,50 };
/*cout << arr2[0] << endl;
cout << arr2[1] << endl;
cout << arr2[2] << endl;
cout << arr2[3] << endl;
cout << arr2[4] << endl;//这样输出很麻烦
//利用循环方式输出数组中的元素
for (int i = 0; i < 5; i++)
{
cout << arr2[i] << endl;
}//如果没有全部赋值,就会自动补0来补齐*/
//3.数据类型 数组名[] = {值1 ,值2....}
int arr3[] = { 90,80,70,60,50,40,30,20,10 };
for (int j = 0; j < 9; j++)
{
cout << arr3[j] << endl;
}
system("pause");
return 0;
}
- `一维数组数组名
#include <iostream>
using namespace std;
int main()
{
//一维数组名称的用途
//1.可以统计整个数组在内存中的长度
int arr[] = { 1,2,3,4,5,6,7,8,9,10 };
cout <<"整个数组占用内存空间为:"<< sizeof(arr) << endl;
cout <<"每个元素占用内存空间为:" << sizeof(arr[0]) << endl;
cout << "数组中元素的个数:" << sizeof(arr)/sizeof(arr[0]) << endl;
//2.可以获取数组在内存中的首地址
cout << "数组的首地址为:" << arr << endl;
cout << "数组的首地址为:" << (int)arr << endl;//将十六进制强转换成十进制
cout << "数组中第一个元素首地址为:" << (int)&arr[0] << endl;
cout << "数组中第二个元素首地址为:" << (int)&arr[1] << endl;
//数组名是常量,不可以进行赋值操作
//arr = 100;这是错误的!
system("pause");
return 0;
}
- 数组案例,五只小猪称体重
#include <iostream>
using namespace std;
int main()
{
//本质在数组中找元素最大值
//访问数组中每个元素,如果这个元素比我认定的最大值大,就更新最大值
int max = 0;
int arr[] = { 300,350,200,400,250 };
for (int i = 0; i < 5; i++)
{
//访问到的数组中的元素比我认为的最大值还大,则更新最大值
if (arr[i] > max)
{
max = arr[i];
}
}
cout << max << endl;
system("pause");
return 0;
}
- 数组元素逆置
#include <iostream>
using namespace std;
int main05()
{
//请声明一个5个元素的数组,并且将元素逆置
//1.创建数组
int arr[5] = { 1,3,2,5,4 };
cout << "数组逆置前:" << endl;
for (int i = 0; i < 5; i++)
{
cout << arr[i] << " ";
}cout << endl;
//2.实现逆置
//2.1记录起始下标位置
//2.2记录结束下标位置
//2.3起始下标与结束下标的元素互换
//2.4起始位置++ 结束位置--
//2.5循环执行2.1操作,直到起始位置>=结束位置
int start = 0;//起始下标
int end = sizeof(arr) / sizeof(arr[0]) - 1;
while (start < end)
{
//实现元素互换
int temp = arr[start];
arr[start] = arr[end];
arr[end] = temp;
//下标更新
start++;
end--;
}
//3.打印
cout << "数组元素逆置后:" << endl;
for (int i = 0; i < 5; i++)
{
cout << arr[i] << " ";
}cout << endl;
system("pause");
return 0;
}
-
冒泡排序
作用:最常见的排序算法,对数组内的元素进行排序 1.比较相邻的元素,如果第一个比第二个大,就交换他们两个 2.对每一对相邻元素做同样的工作,执行完毕,找到一个最大值 3.重复以上步骤,每次比较次数-1,直到不需要比较
#include <iostream>
using namespace std;
int main()
{
//冒泡排序
//作用;最常见的排序算法,对数组内的元素进行排序
//1.比较相邻的元素,如果第一个比第二个大,就交换他们两个
//2.对每一对相邻元素做同样的工作,执行完毕,找到一个最大值
//3.重复以上步骤,每次比较次数-1,直到不需要比较
//利用冒泡排序实现升序序列
int arr[9] = { 4,2,8,0,5,7,1,3,9 };
cout << "排序前:" << endl;
for (int i = 0; i < 9; i++)
{
cout << arr[i] << " ";
}cout << endl;
//开始冒泡排序
//9个数第一次对比8次,第二次对比7次,依次是6 5 4 3 2 1次
//排序轮数依次是1 2 3 4 5 6 7 8次
//排序的总轮数=元素个数-1;
//每轮对比的次数=元素个数-排序轮数;
for (int j = 1; j <= 9 - 1; j++)//总共排序轮数
{
//内层循环对比 次数=元素个数-排序轮数
for (int x = 0; x < 9 - j; x++)
{
//如果第一个数字比第二个数字大,交换两个数字
if (arr[x] > arr[x + 1])
{
int temp = arr[x];
arr[x] = arr[x + 1];
arr[x + 1] = temp;
}
}
}
//排序后的结果
cout << "排序后:" << endl;
for (int i = 0; i < 9; i++)
{
cout << arr[i] << " ";
}cout << endl;
system("pause");
return 0;
}
-
二维数组
二维数组 在一维数组上多加一个维度 二维数组定义方式 1.数据类型 数组名[行数][列数]; 2.数据类型 数组名[行数][列数] = {{数据1,数据2},{数据3,数据4}}; 3.数据类型 数组名[行数][列数] = {数据1,数据2,数据3,数据4}; 4.数据类型 数组名[][列数] = {数据1,数据2,数据3,数据4}; 建议,以上4种定义方式,利用第二种更加直观,提高代码的可读性
#include <iostream>
using namespace std;
int main()
{
//二维数组
//在一维数组上多加一个维度
/*二维数组定义方式
1.数据类型 数组名[行数][列数];
2.数据类型 数组名[行数][列数] = {{数据1,数据2},{数据3,数据4}};
3.数据类型 数组名[行数][列数] = {数据1,数据2,数据3,数据4};
4.数据类型 数组名[][列数] = {数据1,数据2,数据3,数据4};
建议,以上4种定义方式,利用第二种更加直观,提高代码的可读性*/
//1.数据类型 数组名[行数][列数];
int arr[2][3];
arr[0][0] = 1;
arr[0][1] = 2;
arr[0][2] = 3;
arr[1][0] = 4;
arr[1][1] = 5;
arr[1][2] = 6;
/*cout << arr[0][0] << endl;
cout << arr[0][1] << endl;
cout << arr[0][2] << endl;
cout << arr[1][0] << endl;
cout << arr[1][1] << endl;
cout << arr[1][2] << endl;*/
//外层循环打印行数,内层循环打印列数
for (int i = 0; i < 2; i++)
{
for (int j = 0; j < 3; j++)
{
cout << arr[i][j] << endl;
}
}
//2.数据类型 数组名[行数][列数] = { {数据1,数据2},{数据3,数据4} };
int arr2[2][3] = { {1,2,3},{4,5,6} };
for (int i = 0; i < 2; i++)
{
for (int j = 0; j < 3; j++)
{
cout << arr2[i][j] << " ";
}cout << endl;
}
//3.数据类型 数组名[行数][列数] = { 数据1,数据2,数据3,数据4 };
int arr3[2][3] = { 1,2,3,4,5,6 };
for (int i = 0; i < 2; i++)
{
for (int j = 0; j < 3; j++)
{
cout << arr3[i][j] << " ";
}cout << endl;
}
//4.数据类型 数组名[][列数] = { 数据1,数据2,数据3,数据4 };
int arr4[][3] = { 1,2,3,4,5,6 };
for (int i = 0; i < 2; i++)
{
for (int j = 0; j < 3; j++)
{
cout << arr4[i][j] << " ";
}cout << endl;
}
system("pause");
return 0;
}
- 二维数组数组名
#include <iostream>
using namespace std;
int main()
{
//二维数组——数组名用途
//1.二维数组所在内存空间
int arr[2][3] =
{
{1,2,3},//int 6个元素,每个4字节
{4,5,6}
};
cout << "二维数组占用内存空间:" << sizeof(arr) << endl;
cout << "二维数组第一行占用空间:" << sizeof(arr[0]) << endl;
cout << "二维数组第一个占用内存为:" << sizeof(arr[0][0]) << endl;
cout << "二维数组的行数:" << sizeof(arr) / sizeof(arr[0]) << endl;
cout << "二维数组的列数:" << sizeof(arr[0]) / sizeof(arr[0][0]) << endl;
//2.可以查看二维数组的首地址
cout <<"二维数组的首地址:"<< (int)arr << endl;
cout << "二维数组第一行的首地址:" << (int)arr[0] << endl;
cout << "二维数组第二行的首地址:" << (int)arr[1] << endl;
cout << "二维数组第一个元素的首地址:" << (int)&arr[0][0] << endl;
cout << "二维数组第二个元素的首地址:" << (int)&arr[0][1] << endl;
system("pause");
return 0;
}
-
二维数组应用案例
有三名同学(A,B,C),在一次考试中的成绩,请分别输出3名同学总成绩 语文 数学 英语 A 100 100 100 B 90 50 100 C 60 70 80 创建二维数组
#include <iostream>
using namespace std;
#include <string>
int main()
{
//有三名同学(A,B,C),在一次考试中的成绩,请分别输出3名同学总成绩
/* 语文 数学 英语
A 100 100 100
B 90 50 100
C 60 70 80
*/
//创建二维数组
int scores[3][3]=
{
{100,100,100},
{90,50,100},
{60,70,80}
};
string names[3] = { "A","B","C" };
//让每行每一列相加输出
for (int i = 0; i < 3; i++)
{
int sum = 0;
for (int j = 0; j < 3; j++)
{
//cout << scores[i][j] << " ";
sum += scores[i][j];
}cout << names[i] <<"的总分:"<< sum << endl;
}
system("pause");
return 0;
}