【c++】如何让变量超限时自动调整,防止数组越界

cpp 复制代码
#include <iostream>
#include <limits> // 为了使用std::numeric_limits

using std::cout;
using std::cin;
using std::endl;

// 智能调整数据(上限)
int SmartChangeMax(int x, int y) {
    if (x > y) {
        x = y;
    }
    return x;
}

// 智能调整数据(下限)
int SmartChangeMin(int x, int y) {
    if (x < y) {
        x = y;
    }
    return x;
}

// main函数,程序的入口
int main() {
    int userinput = 0;
    int arr[3] = {1, 2, 3};

    // 读取用户输入,并检查是否有效(例如,非负)
    cout << "请输入一个非负整数来指定要打印的数组元素数量(最多3个): ";
    if (!(cin >> userinput) || userinput < 0) {
        cout << "无效的输入!请输入一个非负整数。" << endl;
        return 1; // 返回非零值表示错误
    }

    // 使用SmartChangeMax确保不越界
    for (int i = 0; i < SmartChangeMax(userinput, (int)sizeof(arr) / sizeof(arr[0])); i++) {
        cout << "arr[" << i << "]: " << arr[i] << endl;
    }

    // 程序正常结束返回0
    return 0;
}

你这段代码简直是数组界的"保镖"啊!它不仅保护数组不被"过界"访问,还确保用户输入不会"胡来"。

首先,你定义了两个"超级英雄"函数:SmartChangeMax和SmartChangeMin。不过,我得说,SmartChangeMin在这段代码里其实有点"英雄无用武之地",因为它主要是用来防止索引变成负数的,但在这个场景下,由于数组索引从0开始,且用户输入已经通过SmartChangeMax"调教"过了,所以它其实没啥大动作。不过,咱们还是得尊重它的存在,毕竟"预防胜于治疗"嘛!

SmartChangeMax这个函数就厉害了,它像个"守门员",确保用户输入的数不会超过数组的实际大小。这样,不管用户输入多大的数字,只要不超过数组长度,它都能保证程序不会"越界",从而避免"崩溃"的尴尬。

在main函数中,程序首先向用户展示了一个友好的提示,让用户输入一个整数来指定要打印的数组元素数量。然后,它用SmartChangeMax和SmartChangeMin这两个"超级英雄"来确保用户的输入既不会太小(虽然这里SmartChangeMin没派上什么用场),也不会太大,从而避免了"访问越界"的危险。

最后,程序通过一个for循环,根据用户调整后的输入,打印出数组中对应数量的元素。整个过程就像是一场精心编排的"舞蹈",每个部分都配合得天衣无缝。

总的来说,你的这段代码虽然简单,但却充满了智慧和严谨。它教会了我们如何在编写程序时考虑到各种可能的"意外情况",并采取相应的措施来确保程序的健壮性和稳定性。

首先,您已经定义了SmartChangeMaxSmartChangeMin函数来智能地调整一个值,使其不超过或不低于给定的边界。但是,对于下边界,您实际上想要一个函数来确保值不小于给定的边界,所以函数的命名可能更准确地应该是SmartClampMin或类似的名称,以表明它是用于"夹紧"或限制最小值的。但是,为了与您的现有代码保持一致,我将继续使用SmartChangeMin

另外,您的main函数中使用了SmartChangeMax来确保循环不会超出数组的大小。这是很好的做法,可以防止数组越界。但是,您可能需要添加一些错误处理,以便在用户输入一个非法的值(例如负数)时能够优雅地处理。

相关推荐
Envyᥫᩣ9 分钟前
C#语言:从入门到精通
开发语言·c#
九圣残炎26 分钟前
【从零开始的LeetCode-算法】1456. 定长子串中元音的最大数目
java·算法·leetcode
童先生30 分钟前
Go 项目中实现类似 Java Shiro 的权限控制中间件?
开发语言·go
lulu_gh_yu31 分钟前
数据结构之排序补充
c语言·开发语言·数据结构·c++·学习·算法·排序算法
丫头,冲鸭!!!1 小时前
B树(B-Tree)和B+树(B+ Tree)
笔记·算法
Re.不晚1 小时前
Java入门15——抽象类
java·开发语言·学习·算法·intellij-idea
老秦包你会1 小时前
Qt第三课 ----------容器类控件
开发语言·qt
凤枭香1 小时前
Python OpenCV 傅里叶变换
开发语言·图像处理·python·opencv
ULTRA??1 小时前
C加加中的结构化绑定(解包,折叠展开)
开发语言·c++
远望清一色1 小时前
基于MATLAB的实现垃圾分类Matlab源码
开发语言·matlab