04-数组和字符串

news2025/1/16 17:46:14

概述

同一个数组所有的成员都是相同的数据类型,同时所有的成员在内存中的地址是连续的。
在这里插入图片描述

一维数组

全局数组若不初始化,编译器将其初始化为零。局部数组若不初始化,内容为随机值。

	int a[10] = { 1, 2, 3, 4, 5, 6, 7, 8, 9, 10 };//定义一个数组,同时初始化所有成员变量
	int a[10] = { 1, 2, 3 };//初始化前三个成员,后面所有元素都设置为0
	int a[10] = { 0 };//所有的成员都设置为0
	
	//[]中不定义元素个数,定义时必须初始化
	int a[] = { 1, 2, 3, 4, 5 };//定义了一个数组,有5个成员

数组名是一个地址的常量,代表数组中首元素的地址。

#include<stdio.h>

int main() {
	int a[10] = {1, 2, 3, 4, 5, 6, 7, 8, 9, 10};
	printf("数组名a所表示的地址常量:%p\n", a);
	printf("数组首个元素a[0]的内存地址:%p\n", &a[0]);

	printf("数组a在内存中占%d个字节\n", sizeof(a));
	printf("数组a的元素在内存中占%d个字节\n", sizeof(a[0]));

	printf("开始输出数组a的全部元素:\n");
	for (int i = 0; i < sizeof(a)/sizeof(a[0]); i++) {
		printf("a[%d]=%d\n", i, a[i]);
	}
	return 0;
}

运行上面代码,输出如下:
在这里插入图片描述

二维数组

在内存中并不存在二维数组,二维数组实际的硬件存储器是连续编址的,也就是说内存中只有一维数组,即放完一行之后顺次放入第二行,和一维数组存放方式是一样的。

#include<stdio.h>

int main() {

	//连续赋值
	int a[3][4] = {1, 2, 3, 4, 5};

	//分段赋值
	//int a[3][4] = { {1, 2, 3, 4}, {5, 6, 7, 8}, {9, 10, 11, 12} };

	for (int i = 0; i < 3; i++) {
		for (int j = 0; j < 4; j++) {
			printf("a[%d][%d]=%d\n", i, j, a[i][j]);
		}
	}
}

执行上面的代码,输出如下:
在这里插入图片描述
数组名是一个地址的常量,代表数组中首元素的地址。

#include<stdio.h>

int main() {
	int a[3][4] = { {1, 2, 3, 4}, {5, 6, 7, 8}, {9, 10, 11, 12} };

	printf("二维数组名a所代表的地址常量:%p\n", a);
	//第0个一维数组的数组名为a[0]
	printf("二维数组的首个元素a[0]所代表的地址常量:%p\n", a[0]);
	printf("a[0][0]在内存中的地址为:%p\n", &a[0][0]);

	printf("二维数组a在内存中占%d个字节\n", sizeof(a));
	printf("二维数组中的一行在内存中占%d个字节\n", sizeof(a[0]));
	printf("二维数组中的元素在内存中占%d个字节\n", sizeof(a[0][0]));

	printf("二维数组a的行数:%d\n", sizeof(a)/sizeof(a[0]));
	printf("二维数组a的列数:%d\n", sizeof(a[0])/sizeof(a[0][0]));
	printf("二维数组a的行数*列数:%d\n", sizeof(a)/sizeof(a[0][0]));

	//[]中不定义元素个数,定义时必须初始化
	int b[][4] = {1, 2, 3, 4, 5};
	printf("二维数组b的行数:%d\n", sizeof(b)/sizeof(b[0]));

	return 0;
}

运行上面的代码,输出如下:
在这里插入图片描述

字符数组与字符串

字符数组与字符串区别

  • C语言中没有字符串这种数据类型,可以通过char的数组来替代;
  • 字符串一定是一个char的数组,但char的数组未必是字符串;
  • 数字0(和字符‘\0’等价)结尾的char数组就是一个字符串,但如果char数组没有以数字0结尾,那么就不是一个字符串,只是普通字符数组,所以字符串是一种特殊的char的数组
#include<stdio.h>

int main() {
	//没有'\0'作为结束符,所以hello1不是字符串,只是普通的字符数组
	char hello1[] = {'h', 'e', 'l', 'l', 'o'};//末尾输出乱码
	printf("hello1 = %s\n", hello1);
	//hello2以'\0'作为结束符,所以hello2是字符串
	char hello2[] = { 'h', 'e', 'l', 'l', 'o', '\0'};
	printf("hello2 = %s\n", hello2);
	//以第1个'\0'作为结束符,所以不会输出后面的world
	char hello3[] = { 'h', 'e', 'l', 'l', 'o', '\0', 'w', 'o', 'r', 'l', 'd', '\0'};
	printf("hello3 = %s\n", hello3);
	return 0;
}

在这里插入图片描述

字符串初始化

#include<stdio.h>

int main() {
	char buf[] = {'I', ' ', 's', 'a', 'y', ':', '\0'};
	//编译器在末尾自动补上\0,所以数组长度为13
	char buf2[] = {"Hello world!"};
	printf("数组buf2的长度为:%u\n", sizeof(buf2) / sizeof(char));
	//指定长度,后面没有赋值的元素,自动补0
	char buf3[30] = {"Welcome to"};
	printf("数组buf3的长度为%u\n", sizeof(buf3) / sizeof(char));
	//直接使用字符串初始化,编译器自动在后面补0,常用
	char buf4[] = "our world";
	printf("数组buf4的长度为%u\n", sizeof(buf4) / sizeof(char));


	printf("%s%s\n", buf, buf2);
	printf("C:%s %s!!\n", buf3, buf4);

	//char buf5[2] = { '1', '2', '3' };//数组越界

	char buf5[] = {'a', 'b', 'c', 0, 'd'};
	char buf6[] = {'a', 'b', 'c', '0', 'd'};
	char buf7[] = {'a', 'b', 'c', '\0', 'd'};
	
	printf("输出buf5:%s\n", buf5);
	printf("输出buf6:%s\n", buf6);
	printf("输出buf7:%s\n", buf7);

	//'\0'后面最好不要连着数字,有可能几个数字连起来刚好是一个转义字符
	//'\ddd'八进制字义字符,'\xhh'十六进制转移字符
	// \012相当于\n
	char str[] = "\012abc";
	printf("str == %s\n", str);

	return 0;
}

运行上面的代码,输出如下:
在这里插入图片描述

字符串的输入与输出

gets()

#include <stdio.h>
char *gets(char *s);
功能:从标准输入读入字符,并保存到s指定的内存空间,直到出现换行符或读到文件结尾为止。
参数:
	s:字符串首地址
返回值:
	成功:读入的字符串
	失败:NULL

gets(str)scanf("%s",str)的区别:

  • gets(str)允许输入的字符串含有空格
  • scanf("%s",str)不允许含有空格
#define _CRT_SECURE_NO_WARNINGS
#include<stdio.h>

int main() {

	char str[100];
	printf("请输入一个字符串(gets):\n");
	gets(str);
	printf("您输入的是%s\n", str);

	char str2[100];
	printf("请输入一个字符串(scanf):\n");
	scanf("%s", str2);
	printf("您输入的是%s\n", str2);
	return 0;
}

运行上面的代码,输出如下:
在这里插入图片描述

fgets()

#include <stdio.h>
char *fgets(char *s, int size, FILE *stream);
功能:从stream指定的文件内读入字符,保存到s所指定的内存空间,直到出现换行字符、读到文件结尾或是已读了size - 1个字符为止,最后会自动加上字符 '\0' 作为字符串结束。
参数:
	s:字符串
	size:指定最大读取字符串的长度(size - 1)
	stream:文件指针,如果读键盘输入的字符串,固定写为stdin
返回值:
	成功:成功读取的字符串
	读到文件尾或出错: NULL

fgets()在读取一个用户通过键盘输入的字符串的时候,同时把用户输入的回车也做为字符串的一部分。通过scanfgets输入一个字符串的时候,不包含结尾的“\n”,但通过fgets结尾多了“\n”。fgets()函数是安全的,不存在缓冲区溢出的问题。

#define _CRT_SECURE_NO_WARNINGS
#include<stdio.h>

int main() {
	char str[5];
	
	fgets(str, sizeof(str)/sizeof(char), stdin);
	printf("您输入的是%s\n", str);
	return 0;
}

运行上面代码,执行如下:
在这里插入图片描述

puts()

#include <stdio.h>
int puts(const char *s);
功能:标准设备输出s字符串,在输出完成后自动输出一个'\n'。
参数:
	s:字符串首地址
返回值:
	成功:非负数
	失败:-1

fputs()

#include <stdio.h>
int fputs(const char * str, FILE * stream);
功能:将str所指定的字符串写入到stream指定的文件中, 字符串结束符 '\0'  不写入文件。 
参数:
	str:字符串
	stream:文件指针,如果把字符串输出到屏幕,固定写为stdout
返回值:
	成功:0
	失败:-1

fputs()puts()的文件操作版本,但fputs()不会自动输出一个’\n’。

strlen()

#include <string.h>
size_t strlen(const char *s);
功能:计算指定指定字符串s的长度,不包含字符串结束符‘\0’
参数:
s:字符串首地址
返回值:字符串s的长度,size_tunsigned int类型

#include<stdio.h>
#include<string.h>

int main() {
	char str[] = {'a', 'b', 'c', '\0', 'd'};
	printf("字符串的长度为%u", strlen(str));
	return 0;
}

运行上面的代码,执行结果如下:
在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/532962.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

瑞吉外卖 - 员工信息分页查询功能(7)

某马瑞吉外卖单体架构项目完整开发文档&#xff0c;基于 Spring Boot 2.7.11 JDK 11。预计 5 月 20 日前更新完成&#xff0c;有需要的胖友记得一键三连&#xff0c;关注主页 “瑞吉外卖” 专栏获取最新文章。 相关资料&#xff1a;https://pan.baidu.com/s/1rO1Vytcp67mcw-PD…

NodeJs之调试

关于调试 当我们只专注于前端的时候&#xff0c;我们习惯性F12&#xff0c;这会给我们带来安全与舒心的感觉。 但是当我们使用NodeJs来开发后台的时候&#xff0c;我想噩梦来了。 但是也别泰国担心&#xff0c;NodeJs的调试是很不方便&#xff01;这是肯定的。 但是还好&…

Spring MVC优雅处理业务异常

本文中&#xff0c;我会描述如何在应用程序的不同层次&#xff0c;优雅地处理业务异常。 异常定义 BusinessException基类定义如下&#xff0c;注意异常中携带业务错误码&#xff0c;方便前端处理异常&#xff1a; public class BusinessException extends RuntimeException…

哪些云渲染服务用于多GPU渲染?

众所周知&#xff0c;GPU渲染 可以使用显卡代替CPU进行渲染&#xff0c;可以显着加快渲染速度&#xff0c;因为GPU主要是为快速图像渲染而量身定制的。GPU的诞生是为了应对图形密集型应用程序&#xff0c;这些应用程序会给CPU带来负担并阻碍计算性能。GPU渲染的原理是在多个数据…

信创办公–基于WPS的EXCEL最佳实践系列 (图表)

信创办公–基于WPS的EXCEL最佳实践系列 &#xff08;图表&#xff09; 目录 应用背景操作步骤1、创建图表和图形2、添加其他数据序列3、在源数据的行与列之间切换4、添加图例5、调整图表和图形的大小6、修改图表和图形参数7、应用图表布局和样式8、设置图表和图形的位置9、插入…

4面都过了,最后要价10K,HR说我不尊重华为....

在不知道一个公司的普遍薪资水平的时候&#xff0c;很多面试者不敢盲目的开价&#xff0c;但就因为这样可能使得面试官怀疑你的能力。一位网友就在网上诉说了自己的经历&#xff0c;男子是一位测试员&#xff0c;已经有九年的工作经历了&#xff0c;能力自己觉得还不错。 因为…

单片机课设 - 液晶显示屏显示时间(实验板实现)

目录 前言&#xff1a;本代码涉及的主要知识&#xff1a;代码&#xff08;实验板实现代码&#xff09;&#xff1a; 前言&#xff1a; 设计本代码的主要目的是为了完成期末作业&#xff0c;即在液晶显示屏上显示、时间、日期、温度&#xff0c;以及用按键控制时间、温度的显示。…

Leetcode50. Pow(x, n)

Every day a Leetcode 题目来源&#xff1a;50. Pow(x, n) 解法1&#xff1a;递归 代码&#xff1a; /** lc appleetcode.cn id50 langcpp** [50] Pow(x, n)*/// lc codestart class Solution { public:double myPow(double x, int n){if (n 0)return 1.0;if (n < 0)re…

华为OD机试真题 Java 实现【获取最大软件版本号】【2023Q1 100分】

一、题目描述 Maven版本号定义,<主版本>.<次版本><增量版本>-<里程碑版本> 举例3.1.4-beta 其中,主版本和次版本都是必须的,主版本,次版本,增量版本由多位数字组成,可能包含前导零,里程碑版本由字符串组成。 <主版本>.<次版本>增…

纯代码的3D玫瑰花,有个这个还怕女朋友不开心?

先上效果图&#xff1a; 再上代码&#xff1a; <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><title>Title</title><style>import url("https://fonts.googleapis.com/css2?familyNico…

Anicube NFT 作品集

Anicube 是韩国娱乐公司 Cube Entertainment 和区块链公司 Animoca Brands 的合资公司 Anicube Entertainment 推出的 IP 空间。其主题是音乐元宇宙&#xff0c;各种基于 K-pop 的表演和推广活动将在主舞台和音乐家星球上举行。 此外&#xff0c;这个系列的购买者还将获得特别奖…

web自动化测试:selenium怎么实现关键字驱动

要做 ui 自动化测试&#xff0c;使用关键字驱动可以说是必须会的一种测试方式&#xff0c;它既可以在纯代码的自动化程序中运行&#xff0c;也可以在测试平台中使用。 使用纯代码方式时&#xff0c;自动化工程师先写好一个通用的程序&#xff0c;其他手工测试人员只需要把执行…

gitlab的CICD

大体步骤4步 1.购买阿里云服务器centos 7.6 2.在服务器上安装gitlab-ce 3.在服务器上安装gitlab-runner 4.在gitlab创建一个项目&#xff0c;拉到本地修改后再提交&#xff0c;触发自动部署 视频教程 看不懂文章的&#xff0c;可以看这个视频&#xff0c;超详细gitlab-cicd-…

国产信创适配-东方通TongWeb安装,使用记录

之前项目使用的tomcat容器,需适配东方通 tongweb容器,记录下在国产麒麟ky10.aarch64 服务器下安装东方通容器的过程(对于麒麟内核服务器操作起来和centos7大致一样) 东方通容器是商业的,没有免费版本,企业级安装是公司和东方通联系给了lisence 经过实际测试发现,东方通提…

深度学习技巧应用15-自动机器学习Autogluon的应用技巧

大家好,我是微学AI,今天给大家介绍一下深度学习技巧应用15-自动机器学习Autogluon的应用技巧,Autogluon是一个开源的自动化机器学习工具包,Autogluon的开发目标是为机器学习从业者提供一个高效、易用、可扩展的自动化机器学习工具,让机器学习变得更加简单快捷。本文采用儿…

绘制混淆矩阵(MatLab/Python)

本文主要简单介绍如何绘制混淆矩阵 首先混淆矩阵是机器学习中总结分类模型预测结果的情形分析表&#xff0c;以矩阵形式将数据集中的记录按照真实的类别与分类模型预测的类别判断两个标准进行汇总。 其实混淆矩阵就是用来判断我们的算法的分类准确度的一个可视化矩阵 1…

得物AI平台-KubeAI推理训练引擎设计和实践

1.KubeAI介绍 KubeAI是得物AI平台&#xff0c;是我们在容器化过程中&#xff0c;逐步收集和挖掘公司各业务域在AI模型研究和生产迭代过程中的需求&#xff0c;逐步建设而成的一个云原生AI平台。KubeAI以模型为主线提供了从模型开发&#xff0c;到模型训练&#xff0c;再到推理…

本科毕业生10大高薪专业出炉,IT行业赢麻了

据环球网报道&#xff0c;现在大学毕业生转行率高达80%&#xff01; 非常后悔&#xff01;有不少粉丝向播妞倾诉&#xff0c;曾经以为读了大学就能找到体面的工作&#xff0c;实际上是掉入了天坑专业&#xff0c;成了现实版孔乙己。 大学生找不到对口好工作&#xff0c;似乎已成…

golang web学习随便记6-模板引擎

以下代码是几乎最简单的一个模板&#xff0c;{{ . }} 表示执行模板时将嵌入的数据 <!DOCTYPE html> <html><head><meta http-equiv"Content-Type" content"text/html; charsetutf-8"><title>Go Web 编程</title> <…

openwrt修改web网页默认端口

使用SSH登录openwrt后台&#xff1b; openwrt 中默认使用的web服务器是uhttpd&#xff0c; 进入配置文件路径&#xff1a; cd /etc/config/ 使用vim编辑器修改uhttpd文件 vi uhttpd 修改以上标红部分后面的端口 vim编辑器打开uhttpd 文件 修改完成后点键盘ESC退出编辑状态&a…