C语言一维数组初步学习笔记

数组

可以存储一组或者多组数值的变量,里面包含多个元素,数组的每个成员都是一个数组元素。

一维数组

定义:类型 数组名[常量表达式] = {值1, 值2, 值3…};

int a[3] = {0, 1, 2};
float f[2] = {1.2, 2.3, 3.14};
char str[] = {'h', 'e', 'l', 'l', 'o'};
chat str1 = "iPhone";//这也是定义字符数组的方法,字符数组后面会详细讲解,这里先了解一下

当数组元素个数为变量时,只能声明数组,不能直接赋值:

int length = 4;
int a[length]; //这样可以
int a[length] = {2, 4, 6, 8};//这样的话就会报错

注意事项:

1、系统不会检测数组元素的下标是否越界,编程时,必须保证数组下标不能越界。

2、不能这样定义数组 int array[] = {}; //数组个数和初始值不能同时为空

3、也不能这样定义数组 int array[2] = {1, 2, 3}; //数组的值的个数大于数组的个数

4、数组是一个整体,不能直接参加运算,只能对单个元素进行处理,通常用到数组的地方都会用到循环

常见数组操作
如果初始化数组的时候,数组的元素个数确定,那么常量表达式可以不写:

int a[] = {1, 3, 5, 7, 9};//数组的长度为5 相当于int a[5] = {1, 3, 5, 7, 9};

int 就是数组类型,表示这个数组中的每个元素都是 int 类型。

访问:通过数组名+下标去访问数组中的元素,而且注意数组的下标是从 0 开始的,a[0] 就是第一个元素,a[1] 代表第二个元素,a[2] 代表第三个元素。所以数组的最后一个元素就是 数组的长度 – 1,一定不要写a[3],这样的话就属于数组越界。

在数组的访问的时候我们通常会通过 for 循环来操作,这个操作一般称为遍历

int ages[28];
//循环赋值
for(int i = 0; i < 28; i++)
{
  int age = arc4random() % 13 + 18;//每个人的年龄的范围是:18 ~ 30 之间的随机值
  ages[i] = age;//给每个元素赋值
}
//访问,也叫遍历
for(int i = 0; i < 28; i++)
{
  printf("a[%d] = %d ", i, ages[i]);
}

两个数组的每个元素对应相加,相加的和存放到第三个数组中:

int a1[] = {2, 4, 5, 6, 10};
int a2[] = {1, 3, 4, 5, 6};
int a3[5];
for(int i = 0; i < 5; i++)
{
  a3[i] = a1[i] + a2[i];
  printf("a3[%d] = %d ", i, a3[i]);
}

输出结果为:

a3[0] = 3 a3[1] = 7 a3[2] = 9 a3[3] = 11 a3[4] = 16

数组的长度如何计算:

sizeof(数组名)/sizeof(数组第一个元素)

int arr[] = {2, 3, 4, 6, 7};
int length = sizeof(arr) / sizeof(arr[0]);
printf("length = %d\n", length);

输出结果为:

length = 5

字符数组:用于存放字符变量的数组称为字符数组,有两种定义格式:

char str[4] = {'a', 'b', 'c', 'd'};
char str2[] = "iPhone";//另外一种方式

字符串的输出:

printf("str2 = %s\n", str2);//%s 输出字符串,遇到 '\0' 结束

有'\0'结束标识的字符数组也称为字符串,系统提供了许多的一些字符串的函数

size_t strlen(const char *):计算字符串长度,是字符串的有效长度,不算'\0′

char str[] = "iPhone";
unsigned long length = strlen(str);//strlen 表示有效长度
printf("length = %lu\n", length);

输出结果为:

length = 6

strlen() 的实现原理:就是遍历字符串,当遇到 ‘\0′ 的时候就结束。

char *strcpy(char *, const char *):字符串拷贝

char str1[] = "Unity";
char str2[] = "Android.....";
printf("%s\n", strcpy(str1, str2));

输出结果:

Android

char *strcat(char *, const char *):字符串拼接

char str1[] = "Unity";
char str2[] = " iPhone";
printf("%s\n", strcat(str1, str2));

输出结果:

Unity iPhone

int strcmp(const char str1*, const char str2*):字符串比较,并且根据 str1 按照字典顺序小于、等于或大于 str2 的结果分别返回负整数、0或正整数。该返回值是 str1 和 str2 由前向后逐字符比较时遇到的第一个不相等字符处的字符的差值

char str1[] = "Unity";
char str2[] = "iPhone";
printf("%d\n", strcmp(str1, str2));

输出结果:

代码如下:

-20

指针访问数组
如果pa指向数组中的某个元素,那么pa+1将指向下一个元素,pa+i指向下i个元素。所以,若果pa指向a[0],那么*pa其实就是a[0],*(pa+1)就是a[1],*(pa+i)就是a[i]。根据这个思路,我们可以使用指针来访问数组。

#include <stdio.h>
int main(int argc, char *argv[])
{
 int score[10]={76,85,90,67,59,79,82,95,91,65};
 int wait, length, i;
 length = sizeof(score) / sizeof(score[0]);
 for(i = 0; i < length; i++)
 {
 printf("%d \n", *(score + i));
 }
 scanf("%d", &wait);
}

程序输出:

76
85
90
67
59
79
82
95
91
65

数组下标与指针关系很密切。执行语句 pa = &a[0] 后,pa 和 a 就具有相同的值了,并且 *pa=a[0]。实际上C语言在计算数组下标时也是使用指针来完成的。下标与指针其实是等价的。

当把一个数组名传递给一个函数的时候,实际上传递的是该数组的第一个元素的地址。所以,数组名参数必须是一个指针。

计算字符串长度的程序可以写成以下:

int strlen(char *s)
{
 int n;

  for(n = 0; *s != '\0'; s++)
   n++;
  return n;
}

s 是指针,也就是一个变量,对它进行自增是合法的。

(0)

相关推荐

  • 使用C语言实现vector动态数组的实例分享

    下面是做项目时实现的一个动态数组,先后加入了好几个之后的项目,下面晒下代码. 头文件: # ifndef __CVECTOR_H__ # define __CVECTOR_H__ # define MIN_LEN 256 # define CVEFAILED -1 # define CVESUCCESS 0 # define CVEPUSHBACK 1 # define CVEPOPBACK 2 # define CVEINSERT 3 # define CVERM 4 # define EXP

  • C语言中交换int型变量的值及转换为字符数组的方法

    不使用其他变量交换两个整型的值: #include <stdio.h> void main(){ int a = 3; int b = 4; a = a ^ b;//使用异或交换 b = b ^ a; a = a ^ b; printf("%d, %d\n", a, b); a = a - b;//使用加减交换 b = a + b; a = b - a; printf("%d, %d\n", a, b); a ^= b ^= a ^= b; printf

  • C语言找出数组中的特定元素的算法解析

    问题描述:一个int数组,里面数据无任何限制,要求求出所有这样的数a[i],其左边的数都小于等于它,右边的数都大于等于它.能否只用一个额外数组和少量其它空间实现.       思路:如果能用两个辅助数组,那么相对来说简单一点,可定义数组Min和数组Max,其中Min[i]表示自a[i]之后的最小值(包括a[i]),Max[i]表示自a[i]之前元素的最大值.有了这两个辅助数组后,对于a[i],如果它大于Max[i-1]并且小于Min[i+1],那么就符合要求.       但是题目要求是只用一个

  • C语言 数组指针详解及示例代码

    数组(Array)是一系列具有相同类型的数据的集合,每一份数据叫做一个数组元素(Element).数组中的所有元素在内存中是连续排列的,整个数组占用的是一块内存.以int arr[] = { 99, 15, 100, 888, 252 };为例,该数组在内存中的分布如下图所示: 定义数组时,要给出数组名和数组长度,数组名可以认为是一个指针,它指向数组的第 0 个元素.在C语言中,我们将第 0 个元素的地址称为数组的首地址.以上面的数组为例,下图是 arr 的指向: 下面的例子演示了如何以指针的方

  • C语言数组指针的小例子

    1.功能:输入6个学生的5门课程成绩,计算出每个学生的平均分和每门课程的平均分.2.C语言实现代码:(其实就是用二维数组来实现的,二维数组的引用传递使用数组指针来完成) 复制代码 代码如下: #include <stdio.h>#define STUDENT 5#define SCORE 6void input_array(float (*score)[STUDENT]);void avg_score(float (*score)[STUDENT]);void avg_course(float

  • 一波C语言字符数组实用技巧集锦

    字符数组倒序 #include <stdio.h> void daoxu(char str[]){ int i; char temp; for(i = 0; i < strlen(str) / 2 ; i ++){ temp = str[i]; str[i] = str[strlen(str) - i-1]; str[strlen(str) - i-1] = temp; } } 单词计数    int wordCount(char str[]){ int i; int count = 0

  • C语言将数组中元素的数排序输出的相关问题解决

    问题描述:输入一个正整数数组,将它们连接起来排成一个数,输出能排出的所有数字中最小的一个.例如输入数组{32,  321},则输出这两个能排成的最小数字32132.请给出解决问题的算法,并证明该算法.       思路:先将整数数组转为字符串数组,然后字符串数组进行排序,最后依次输出字符串数组即可.这里注意的是字符串的比较函数需要重新定义,不是比较a和b,而是比较ab与 ba.如果ab < ba,则a < b:如果ab > ba,则a > b:如果ab = ba,则a = b.比较

  • 直观理解C语言中指向一位数组与二维数组的指针

    一维数组和指针: 对于一位数组和指针是很好理解的: 一维数组名: 对于这样的一维数组:int a[5];  a作为数组名就是我们数组的首地址, a是一个地址常量 . 首先说说常量和变量的关系, 对于变量来说, 用箱子去比喻再好不过了, 声明一个变量就声明一个箱子,比如我们开辟出一个苹果类型的箱子, 给这个变量赋值就是把盛放苹果的箱子中放入一个实实在在的苹果, 这就是变量的赋值.  而对于数组来说, 就是一组类型相同的箱子中,一组苹果箱子, 可以放入不同的苹果. 一维数组空间: 变量被声明后, 我

  • 简单分析C语言中指针数组与数组指针的区别

    首先来分别看一下,指针数组的一个小例子: #include <stdio.h> #include <string.h> int lookup_keyword(const char*key, const char* table[], const int size) { int ret = -1; int i = 0; for(i=0; i<size; i++) { if (strcmp(key, table[i]) == 0) { ret = i; break; } } ret

  • C语言中二维数组指针的简要说明

    C语言中,指针是一个复杂但又灵活多变的知识点,我们知道,在一维数组中,对于一个数组a[],*a,a,&a,都表示a的首地址,但如果与二维数组混合使用,就显得更为复杂了.例如对于一个二维数组 a[2][4]={{1,2.3},{4,5,6}} a+i,&a[i],*(a+i),a[i], 这四个表达式到底表示什么呢? 先告诉答案吧,其实这几个表达式都是指向同一个地址的,也许你会很诧异,也会很疑惑,怎么会是这样呢!!事实证明就是这样的, C语言中,指针是一个复杂但又灵活多变的知识点,我们知道,

  • C语言中数组作为函数的参数以及返回值的使用简单入门

    函数通过数组作为参数 如果想通过一个一维数组作为函数的参数,就必须声明函数形式参数,使用以下三种方式与所有三个声明方法之一产生类似的结果,因为每一种方式告诉编译器,一个整数指针将会要被接收.类似的方式,可以使用多维数组形式参数. 方式-1 形式参数为指针如下.在下一章将学习什么是指针. void myFunction(int *param) { . . . } 方式-2 如下形式数组参数的大小: void myFunction(int param[10]) { . . . } 方式-3 如下形式

随机推荐