c++第六篇

简介: c++第六篇
#include<bits/stdc++.h>
using namespace std;
int main()
{
  //一维数组的定义方式
  //定义方式1
  //数据类型 数组名[元素个数];
  int score[10];
  //利用下标赋值
  score[0] = 100;
  score[1] = 99;
  score[2] = 85;
  //利用下标输出
  cout << score[0] << endl;
  cout << score[1] << endl;
  cout << score[2] << endl;
  //第二种定义方式
  //数据类型 数组名[元素个数] =  {值1,值2 ,值3 ...};
  //如果{}内不足10个数据,剩余数据用0补全
  int score2[10] = { 100, 90,80,70,60,50,40,30,20,10 };
  //逐个输出
  //cout << score2[0] << endl;
  //cout << score2[1] << endl;
  //一个一个输出太麻烦,因此可以利用循环进行输出
  for (int i = 0; i < 10; i++)
  {
    cout << score2[i] << endl;
  }
  //定义方式3
  //数据类型 数组名[] =  {值1,值2 ,值3 ...};
  int score3[] = { 100,90,80,70,60,50,40,30,20,10 };
  for (int i = 0; i < 10; i++)
  {
    cout << score3[i] << endl;
  }
  //一维数组的数组名
    //数组名用途
  //1、可以获取整个数组占用内存空间大小
  int arr[10] = { 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 << "数组中第一个元素地址为: " << &arr[0] << endl;
  cout << "数组中第二个元素地址为: " << &arr[1] << endl;
  //arr = 100; 错误,数组名是常量,因此不可以赋值 
  //冒泡排序
  int val;
  cin>>val;
  int a[val];
  for(int i=0;i<val;i++){
    cin>>a[i];
  }
  //倒三角 
  for(int i=0;i<val-1;i++){
    for(int j=0;j<val-1-i;j++){
      if(a[j]>a[j+1]){
        int t=a[j];
        a[j]=a[j+1];
        a[j+1]=t;
      }
    }
  }
  for(int i=0;i<val;i++){
    cout<<a[i]<<endl;
  }
  //二维数组的定义方式
    //方式1  
  //数组类型 数组名 [行数][列数]
  int arr1[2][3]; 
  arr1[0][0] = 1;
  arr1[0][1] = 2;
  arr1[0][2] = 3;
  arr1[1][0] = 4;
  arr1[1][1] = 5;
  arr1[1][2] = 6;
  for (int i = 0; i < 2; i++)
  {
    for (int j = 0; j < 3; j++)
    {
      cout << arr1[i][j] << " ";
    }
    cout << endl;
  }
  //方式2 
  //数据类型 数组名[行数][列数] = { {数据1,数据2 } ,{数据3,数据4 } };
  int arr2[2][3] =
  {
    {1,2,3},
    {4,5,6}
  };
  //方式3
  //数据类型 数组名[行数][列数] = { 数据1,数据2 ,数据3,数据4  };
  int arr5[2][3] = { 1,2,3,4,5,6 }; 
  //方式4 
  //数据类型 数组名[][列数] = { 数据1,数据2 ,数据3,数据4  };
  int arr4[][3] = { 1,2,3,4,5,6 }; 
  //二维数组名称
    int arr3[2][3] =
  {
    {1,2,3},
    {4,5,6}
  };
  cout << "二维数组大小: " << sizeof(arr3) << endl;
  cout << "二维数组一行大小: " << sizeof(arr3[0]) << endl;
  cout << "二维数组元素大小: " << sizeof(arr3[0][0]) << endl;
  cout << "二维数组行数: " << sizeof(arr3) / sizeof(arr3[0]) << endl;
  cout << "二维数组列数: " << sizeof(arr3[0]) / sizeof(arr3[0][0]) << endl;
  //地址
  cout << "二维数组首地址:" << arr3 << endl;
  cout << "二维数组第一行地址:" << arr3[0] << endl;
  cout << "二维数组第二行地址:" << arr3[1] << endl;
  cout << "二维数组第一个元素地址:" << &arr3[0][0] << endl;
  cout << "二维数组第二个元素地址:" << &arr3[0][1] << endl;
  //考试成绩统计
  //创建二维数组
  int scores[3][3]{
    { 100,100,100 },  { 50,90,100 },  { 60,70,80 }
  } ;
  for(int i=0;i<3;i++)
  {
    int sum=0;
    for(int j=0;j<3;j++){
      sum+=scores[i][j];
    }
    cout<<sum<<endl;
  }
  return 0;
}


相关文章
|
8月前
|
Java
【Java开发指南 | 第十一篇】Java运算符
【Java开发指南 | 第十一篇】Java运算符
30 2
|
8月前
|
存储 SpringCloudAlibaba Java
手把手教你,从零开始搭建Spring Cloud Alibaba!这份笔记太牛了
Spring Cloud Alibaba 是阿里巴巴提供的微服务开发一站式解决方案,是阿里巴巴开源中间件与 Spring Cloud 体系的融合。
|
并行计算 安全 Java
2023年Java核心技术第十一篇(篇篇万字精讲)
2023年Java核心技术第十一篇(篇篇万字精讲)
66 2
|
移动开发 JavaScript 前端开发
面试题练习第五篇
面试题练习第五篇
94 1
|
存储 安全 Java
2023年Java核心技术面试第六篇(篇篇万字精讲)
2023年Java核心技术面试第六篇(篇篇万字精讲)
77 0
|
前端开发 C# 数据库管理
(3) MasaFramework 入门第三篇,使用MasaFramework
(3) MasaFramework 入门第三篇,使用MasaFramework
117 0
(3) MasaFramework 入门第三篇,使用MasaFramework
|
缓存 监控 Java
膜拜!Alibaba最新发布SprinBoot:进阶原理实战与面试题分析指南
本书对Spring Boot的各项功能特性及其最佳实践、实现原理展开讨论,涵盖了核心容器、Web服务、内置缓存、数据访问、并发编程、监控和扩展等一系列核心主题,这些核心主题也广泛应用于Spring家族中的其他开发框架。
152 0