首页 > 其他分享 >数组:性能优化与错误处理的艺术

数组:性能优化与错误处理的艺术

时间:2024-08-05 16:54:16浏览次数:18  
标签:arr int 元素 索引 数组 printf 错误处理 优化

引言

在编程过程中,我们会发现这么一件事,有时候需要用到很多变量,十个、百个,甚至千个,如果一个个变量都去声明的话,那么工作量是非常大的,也导致代码很臃肿,所以这个时候数组就出现了。数组可以用来存储一系列数据类型一致的数据,这让我们在操作数据的时候会来的更加简易高效,接下来将分析数组的基本用法,希望对您有所帮助。


一维数组(常用)

在这里插入图片描述

  • 定义:用于在计算机内存中连续存储相同类型的数据。它由一个索引(或下标)和对应的值组成,其中索引用于访问数组中的特定元素。在一维数组中,索引通常是整数,从0开始,一直到数组长度减1

  • 固定大小:在声明一维数组时,需要指定数组能够容纳的元素数量,这个数量在数组声明之后通常不能改变(尽管在某些编程语言中,可以使用动态数组或类似结构来模拟可变大小的数组)。

  • 索引访问:通过索引(或下标)来访问数组中的元素。索引通常是从0开始的,即第一个元素的索引为0,第二个元素的索引为1,以此类推。

  • 同类型数据:数组中的所有元素都必须是相同的数据类型,如整型数组只能存放整型数据,浮点型数组只能存放浮点型数据。

  • 一维数组的元素修改(直接进行赋值操作)
/*例子:将数组下标为2的元素进行修改*/
int arr[5] = {0};
printf("%d\n",arr[2]);		//这个时候输出arr[2]的值是0
arr[2] = 6;					//将arr[2]的值修改为6
printf("%d\n",arr[2]);		//这个时候输出arr[2]的值是6
  • 一维数组的声明和初始化
// 声明一个整型数组,包含5个元素,初始值未指定  
int arr[5];  
  
// 声明并初始化一个整型数组  
int arr2[5] = {1, 2, 3, 4, 5};  
  
// 也可以使用部分初始化,未指定的元素将自动初始化为0  
int arr3[5] = {1, 2}; // arr3[0] = 1, arr3[1] = 2, arr3[2] = 0, arr3[3] = 0, arr3[4] = 0
  • 一维数组的输入和输出(使用循环)
int arr[10]; // 声明一个长度为10的整型数组  
  
// 通过for循环接收用户输入的数组元素  
for(i = 0; i < 10; i++) {  
    scanf("%d", &arr[i]);  
}

// 通过另一个for循环输出数组元素  
printf("您输入的数组元素为:\n");  
for(i = 0; i < 10; i++) {  
    printf("%d ", arr[i]);  
}  
  • 一维数组的元素查找
int arr[] = {1, 3, 5, 7, 9, 11, 13, 15}; // 定义并初始化一维数组  
int n = sizeof(arr) / sizeof(arr[0]); // 计算数组arr的长度  
int target; // 要查找的目标元素  
int found = 0; // 标记是否找到目标元素  
  
printf("请输入需要查找的元素: ");  
scanf("%d", &target); // 输入要查找的元素  
  
// 遍历数组,查找目标元素  
for(int i = 0; i < n; i++) {  
    if(arr[i] == target) {  
        printf("Element found at index %d.\n", i); 
        found = 1;  
        break; // 找到后退出循环  
    }  
}  
 
// 如果没有找到目标元素  
if(!found) {  
    printf("Element not found.\n");  
}  
  • 一维数组的元素删除(这里的删除指的是对元素进行覆盖,不是在内存中删除)
/*在这里length和element分别代表arr数组的长度和要删除的元素
  注意:这里的长度不等价与数组的大小,长度指的是有效元素的个数,比如int a[10], 这个时候数组大小
  	   是10,是一个定值,但是我只需要用到数组的前6个大小,后面4个暂时用不到,那么就称呼长度为6.
*/
for (int i = 0; i < length; i++) {
	if (arr[i] == element) {
		// 找到要删除的元素,将其后的所有元素向前移动一位  
		for (int j = i + 1; j < length; j++) {
			arr[j - 1] = arr[j];
		}
		length--; // 数组长度减一  
		break; // 找到并处理后退出循环  
	}
}
  • 一维数组的元素插入
int arr[10] = { 1, 2, 4, 5, 6 }; // 假设我们有一个大小为10的数组,但只初始化了部分元素  
int length = 5; // 当前数组实际使用的元素个数  
int position, element;

printf("清输入新元素插入的位置: ");
scanf("%d", &position);
printf("请输入插入元素的值: ");
scanf("%d", &element);

// 检查位置是否有效)  
if (position < 0 || position > length) {
	printf("插入的位置不合法!\n");
}
else{
	// 这里不考虑数组元素占满的情况
	for(int i = length - 1; i >= position; i--){
		// 从数组下标length - 1 到position对应的元素都往后移动一个空间
		arr[i + 1] = arr[i];
	}
	//移动完成后,将元素element插入到数组的position位置
	arr[position] = element;
	printf("插入成功!\n");
}
  • 一维数组的排序(排序的方法有多种,这里以冒泡排序进行升序排序为例进行讲解)
// 冒泡排序函数,对arr数组进行升序排序  
void bubbleSort(int arr[], int n) {  
    int i, j, temp;  
    for (i = 0; i < n-1; i++) {  
        // 最后的i个元素已经排好序,不需要再比较  
        for (j = 0; j < n-i-1; j++) {  
            if (arr[j] > arr[j+1]) {  
                // 如果当前元素大于下一个元素,则交换它们  
                temp = arr[j];  
                arr[j] = arr[j+1];  
                arr[j+1] = temp;  
            }  
        }  
    }  
} 



二维数组(使用频率较低,不做过多讲解,有兴趣可以私信跟我探讨)

  • 定义:二维数组是在计算机内存中用于连续存储相同类型数据的结构,但它以矩阵(或表格)的形式组织。它由两个索引(或下标)和对应的值组成,其中第一个索引代表行,第二个索引代表列,这两个索引共同用于访问数组中的特定元素。在二维数组中,索引通常是从0开始的,即第一个元素的行索引和列索引都为0
  • 二维数组的初始化以及遍历输出
#include <stdio.h>  
  
int main() {  
    // 定义一个3行4列的二维数组  
    int matrix[3][4] = {  
        {1, 2, 3, 4},  // 第一行  
        {5, 6, 7, 8},  // 第二行  
        {9, 10, 11, 12} // 第三行  
    };  
  
    // 使用嵌套的for循环遍历并打印二维数组  
    for (int i = 0; i < 3; i++) { // 外层循环遍历行  
        for (int j = 0; j < 4; j++) { // 内层循环遍历列  
            printf("%d ", matrix[i][j]); // 打印当前元素  
        }  
        printf("\n"); // 每打印完一行后换行  
    }  
  
    return 0;  
}

标签:arr,int,元素,索引,数组,printf,错误处理,优化
From: https://blog.csdn.net/weixin_48808100/article/details/140925121

相关文章

  • SQL优化
    1.千万级大表第一优化你的sql和索引;第二加缓存,memcached,redis;第三以上都做了后,还是慢,就做主从复制或主主复制,读写分离,可以在应用层做,效率高,也可以用三方工具,第三方工具推荐360的atlas,其它的要么效率不高,要么没人维护;第四如果以上都做了还是慢,不要想着去做切分,mysql自带分区......
  • 【动态规划】力扣918. 环形子数组的最大和
    给定一个长度为n的环形整数数组nums,返回nums的非空子数组的最大可能和。环形数组意味着数组的末端将会与开头相连呈环状。形式上,nums[i]的下一个元素是nums[(i+1)%n],nums[i]的前一个元素是nums[(i-1+n)%n]。子数组最多只能包含固定缓冲区nu......
  • lg省选计划笔记-基础优化技巧1
    基础优化技巧1三分求单峰函数极值点丢弃极值点一定不在的点,注意不能用于非严格单调的函数。由于区间长度可以随便取,可以把分段点取得很近,这个时候就相当于二分斜率前面比0大,极值点处等于0,后面小于001分数规划略。模型特征:答案是比率形式(取对数可以把根式和次方转换为乘......
  • MES系统如何精准采集与对接设备数据,全面优化设备管理
    一、MES系统如何采集和对接设备数据MES系统(ManufacturingExecutionSystem,制造执行系统)采集和对接设备数据主要通过以下几种方式实现:手工录入:这是最基础的数据采集方式,通过操作人员在MES系统界面上手动输入数据。适用于数据量较小、实时性要求不高的场景,但存在数据准确......
  • 速卖通、美客多自养号经验分享:满足测评条件与Listing优化秘诀
    Listing,即产品在电商平台上的展示页面,是吸引顾客、促进销售的关键窗口。为了在众多竞品中脱颖而出,卖家需精心优化Listing的每一个细节,从类别选择到描述撰写,每一步都至关重要。以下是Listing优化的五大核心策略:1. 类别精准定位分类精准:正确选择产品所属的分类,甚至可考虑添加......
  • 补充:关于GRU的详细运作原理以及特殊的优化思路
    1.GRU的基本结构和运作原理1.1GRU的基本概念GatedRecurrentUnit(GRU)是一种简化版的循环神经网络(RNN),它通过引入门控机制来解决长期依赖问题,同时减少参数数量以降低计算复杂度。1.2GRU的结构详解GRU包含两个门控机制:更新门(updategate)和重置门(resetgat......
  • [学习笔记]后缀数组(Suffix Array)
    后缀数组(suffixarray)是一个通过对字符串的所有后缀经过排序后得到的数组。后缀数组被Manber和Myers于1990年提出,作为对后缀树的一种替代,更简单以及节省空间。它们也被GastonGonnet于1987年独立发现,并命名为“PAT数组”。后缀数组有很多奇妙的性质,这些性质可以帮......
  • js动态构建属性名并访问其对象属性(动态的对象或着数组名)
    js动态构建属性名并访问其对象属性(动态属性访问)在开发中有时会遇到这种情况:你写了很多的函数,写完发现他们的操作逻辑都是相同的,但是原始数据不同,如:/*获取区域,道路拥堵指数对应的色标*/makeCongestionColor(num){letoutColor='#fff'letcol......
  • C 语言(二)数组与字符串
    C语言(二)数组与字符串1.数组所谓数组,就是一个集合,里面存放了相同类型的数据元素特点1:数组中的每个数据元素都是相同的数据类型特点2:数组是由连续的内存位置组成的1.1一维数组定义://伪代码数据类型数组名【数组长度】;数据类型数组名【数组长度】={值1,值2};......
  • 网课-基础优化技巧
    P3382三分三分等价于二分斜率。因此完全可以求导后直接做二分。01分数规划整体二分分治,对多个个体同时做二分。P3527[POI2011]MET-Meteors考虑对单个星球二分。则基础想法是以时间为线段树下标,在主席树中二分。考虑拓展到整体二分。则基础想法是二分时间,试着加入陨......