QT第十十一课程笔记 - 数组和练习

2.2.7 数组

在 C++ 中,数组是一种存储固定大小的相同类型元素的序列。数组的所有元素都存储在连续的内存位置上。这种数据结构非常适合于存储具有固定数量和相同数据类型的元素集合。

声明数组

声明数组的基本语法如下:

数据类型 数组名[数组大小];

例如,声明一个类型为 int 的数组,包含 10 个元素:

int myArray[10];

初始化数组

在声明数组时,您可以同时初始化数组:

int myArray[5] = {10, 20, 30, 40, 50};

如果您在初始化数组时没有指定所有元素的值,未初始化的元素将被自动设置为该数据类型的默认值(对于基本数据类型通常是 0):

int myArray[5] = {10, 20}; // 其余元素将被初始化为 0

访问数组元素

您可以通过指定索引来访问数组中的元素。数组索引是从 0 开始的,所以数组的第一个元素是 数组名[0],第二个元素是 数组名[1],依此类推:

int value = myArray[2]; // 访问第三个元素

示例

以下是使用数组的简单示例:

#include <iostream>
using namespace std;

int main() {
    int myArray[5] = {10, 20, 30, 40, 50};
	
    // 输出所有数组元素的值
    for(int i = 0; i < 5; ++i) {
        cout << "Element at index " << i << ": " << myArray[i] << endl;
    }

    return 0;
}

注意事项

  • 数组的大小必须在编译时已知,且不能更改。
  • 数组索引越界是常见的错误,可能会导致未定义的行为。
  • 对于更复杂的用例,您可能需要使用 C++ 的标准模板库(STL)中的容器,如 std::vector,它提供了可以动态改变大小的数组。
  • 数组的元素存储在连续的内存位置上,这使得访问数组元素非常快。

2.2.8 练习

  • 计算器支持加减乘除
#include <iostream>
using namespace std;

int add(int a,int b)
{
    return a+b;
}

int min(int a,int b)
{
    return a-b;
}

int mul(int a,int b)
{
    return a*b;
}

float divRet(int a,int b)
{
    return (float)a/b;
}

int main() {

    int a;
    int b;
    char calWay;
    while(1){
        cout << "请输入两个数:"<< endl;
        cin >> a;
        cin >> b;

        cout<<"请输入运算符号:+ - * /" <<endl;
        cin >> calWay;

        switch(calWay){
        case '+':
            printf("两数之和是%d\n",add(a,b));
            break;
        case '-':
            printf("两数之差是%d\n",min(a,b));
            break;
        case '*':
            printf("两数之积是%d\n",mul(a,b));
            break;
        case '/':
            printf("两数之余是%f\n",divRet(a,b));
            break;
        default:
            printf("运算符输入错误,请重新输入\n");
        }
    }
}

加入Lambda表达式和回调函数的做法(只是为了验证学习,此等方法比较low

#include <iostream>

using namespace std;

/*
int add(int a, int b)
{
    return a+b;
}

int minu(int a, int b)
{
    return a-b;
}

int mul(int a, int b)
{
    return a*b;
}

double diliv(int a, int b)
{
    return (double)a/b;
}
*/

int calculator(int a, int b, int (*p)(int a, int b))
{
    cout << "开始计算" << endl;
   // p(a,b);
}

int main()
{
    int a = 0;
    int b = 0;
    char cal;

    while(1){
        cout << "请输入两个数:" << endl;
        cin >> a;
        cin >> b;
        cout << "请输入运算符+,-,*,/" << endl;
        cin >> cal;
       // auto minu = [a,b]()->int{ return a - b;};
        switch(cal){
        case '+':
            cout << calculator(a,b,[](int a, int b){return a + b;}) << endl;
            break;
        case '-':
            cout << calculator(a,b,[](int a, int b){return a - b;}) << endl;
            break;
        case '*':
            cout << calculator(a,b,[](int a, int b){return a * b;}) << endl;
            break;
        case '/':
            cout << calculator(a,b,[](int a, int b){return a / b;}) << endl;
            break;
        }
    }

    //  cout << "Hello World!" << endl;
    return 0;
}

  • 9
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

上官可编程

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值