【C语言】字符串、字符数组

news2024/11/29 8:58:43

目录

写在开头

正文

一、字符串的本质

二、输入函数scanf和gets

三、输出函数printf和puts

四、字符串的长度——strlen

五、字符串的复制——strcpy

六、字符串的比较函数

七、实战练习

八、二维字符数组——字符串数组

写在最后


写在开头

看了标题,是不是一头雾水,两者有什么关系呢?来看几个例子

char ch='a'                // 正确表示,字符常量 

char ch="abc"           // 错误表示,char 类型只能存储一个字节的数据
char ch[]="ABC";      //正确表示,字符串。
char ch[5]={"ABC"};  //正确表示,字符串。
char ch[4]={'A','B','C'} ; //正确,字符数组,4个字符常量


正文

一、字符串的本质

实质上是以'\0'结尾的字符数组,C语言中 数字0和'\0'在字符数组中都是表示字符串结束的意思

字符串:只有以'\0'结尾的字符集合才能称为字符串。在用字符数组存放字符串,若指定字符数组的大小,那么其大小至少要比字符串的长度大1。

char str[ ]={'a','b','c','d'};         不是字符串(没有‘\0’)

char str[4]={'a','b','c','d'};        不是字符串,没有剩余空间初始化为0

char str[10]={'a','b','c','d'};      是字符串,编译器会自动将剩余空间初始化为0,0和‘\0’等价,

char str[10]={"abcd"};            是字符串,编译器会自动在d末尾补‘\0’

char str[10]="abcd";              是字符串,编译器会自动在d末尾补‘\0’

char str[ ]={'a','b','c','d'};    等价于  char str[4]={'a','b','c','d'}; 

char str[5]={'a','b','c','d'};   等价于  char str[5]={'a','b','c','d','\0'};  等价于   char str[5]={"abcd"};


二、输入函数scanf和gets

gets(字符数组变量名)scanf
输入的字符串可以包含空格字符输入的字符串不能包含空格字符
只能输入一个字符串可连续输入多个字符串(使用%s%s%S)
不能限定字符串的长度可限定字符串的长度(使用%ns)
遇到回车符结束

遇到空格符或回车符结束

特别注意

  • 用gets函数接收字符串时,无法限制输入字符的长度,只能根据需要定义一个足够的的字符数组
  • 用scanf函数会自动在字符串后加'\0'
char str[30];
scanf("%s",str);  //不要写成&str,因为str本身就为地址

char str1[30],str2[30],str3[30];
scanf("%s%s%s",str1,str2,str3);
//输入时字符串之间用空格隔开,表示输入三个字符

char str1[10];
scanf("%9s",str);
//最多读取9个非空字符,str最后一个数据单元存放'\0'

char str1[11];
gets(str);
//I Love You 就会存进str1中

三、输出函数printf和puts

puts(字符串的地址)printf
输出字符串所有字符输出字符串内的每个字符,直到遇到第一个‘\0’
将字符串结束标志'\0'转换为'\n'%s对应地址必须是首元素的地址
无法控制输出格式,等同printf("%s\n")可以添加其他的转义字符

输出乱码的出现:

char str[] = {'a','b','c','d'};
puts(str);
printf("%s",str);

由于puts函数迟迟遇不到'\0',就会一直打印,有时就会出现 烫烫烫一类的奇怪字符,原理大家可以在平台搜索哈。

控制格式的输出

#include<stdio.h>
int main()
{
	char str[] = "I Love You";
    printf(">>%2s<<\n",str);
    printf(">>%-15s<<\n",str);
    printf(">>%15s<<\n",str);
	return 0;
 } 

 程序解释

  • %ns 输出,原本字符超过n位,按原样输出
  • %-ns输出,原本字符未超过n位,剩下的位置用空格补全,实行左对齐
  • %ns输出,原本字符未超过n位,剩下的位置用空格补全,实行右对齐

四、字符串的长度——strlen

  • 计算的字符长度不包括'\0'
  • 计算字符串长度时是从给定的起始地址开始的
strlen(字符串的地址);//头文件string.h

char str[]="0123456789";

printf("%d",strlen(str));//结果为10

printf("%d",strlen(&str[5]));//结果为5

五、字符串的复制——strcpy

头文件string.h
strcpy(字符数组1,字符数组2)strncpy(字符数组1,字符数组2,长度n)
将字符串2复制到字符串1中将字符串2中的前n个字符复制到字符串1中
包括字符串结尾的'\0'不包括字符串结尾的'\0

自定义函数进行字符串的复制

void Mystrcpy1(char *str1,char *str2)
{//把str1和str2当作数组看待
	int i=0;
	for(i=0;str2[i]!='\0';i++)
	{
		str1[i] = str2[i];
	}

    //尤其重要str2的'\0'不会传到str1,要添加上,以免输出时出错
	str1[i] = '\0';
}

六、字符串的比较函数

头文件stdio.h
strcmpstrncmp
strcmp(字符串1,字符串2)strncmp(字符串1,字符串2,长度n)
将两个字符串逐个字符进行比较其ASCII码的大小,直到遇到不同的字符或'\0'为止,如果全部字符都相同,则两个字符串相等。否则以第一个不相同的字符的比较结果作为标准将字符串1前n个字符与字符串2前n个字符进行比较,比较规则同strcmp

stricmp:与strcmp的用法基本相同,只不过在比较两个字符串时不区分大小写

strnicmp:与strncmp的用法基本相同,只不过在比较两个字符串时不区分大小写


七、实战练习

输入一行字符,统计单词的个数,单词之间用空格间隔

思路:遍历字符,发现空格,word=0,发现字符,word=1,计数器count+1

#include<stdio.h>
int main()
{
	char str[100];
	int i=0,count=0,word=0;
	gets(str);
	for(i=0;str[i]!='\0';i++)
	{
		if(str[i]==' ')
		{
			word=0;
		}
		else
		{
			if(word==0)
			{
				word=1;
				count++;
			} 
		}
	}
	printf("共有%d个单词",count);
	return 0;
 } 

八、二维字符数组——字符串数组

当构成数组的元素是字符串的时候,这个数组就称字符串数组,实质上就是字符型的二维数组

初始化:

  • char str[行数m][列数n]={ 字符串1,字符串2,---,字符串m }
  • char name[][20]={ "ZhangSan","LiSi","WangWu","ZhaoLiu","XingChen" }
  • 每个字符串的长度应小于或等于 n-1(结尾的'\0'需要占一个单元)

综合运用:

输入多个城市的名字,按照升序排列

#include<stdio.h>
 #include<string.h>
 #define Citynum 3
 int main()
 {
 	int i,j,k;
 	char city[Citynum][20];
 	char str[50];
 	int num=0;
 	for(i=0;i<Citynum;i++)
 	{
 		//判断部分 
 		printf("Input the name of the %dth city:",i+1);
 		gets(str);//输入城市名
//		if(str[i]==0)   //空串表示输入结束 
//		   break;
//		if(strlen(str)>19)  //城市名超过19时,重输 
//		{
//			i--;
//			continue;
//		 } 
		 
		 //判断后存进数组
		 strcpy(city[i],str);
		 num++; 
	 }
	 
	 //升序 
	 for(i=0;i<num-1;i++)
	 {
	 	k=i;//字符串数组中最小的下标 
	 	for(j=i+1;j<num;j++)
	 	{
	 		if(stricmp(city[k],city[j])>0)
	 		   k=j;
	 		if(k!=i)
	 		{
	 			strcpy(str,city[i]);
	 			strcpy(city[i],city[k]);
	 			strcpy(city[k],str); 
			 }
		 }
	 }
	 //排序结果 
	 for(i=0;i<num;i++)
	 	printf("%s ",city[i]); 
     printf("\n"); 
 	return 0;
 }
 

写在最后

👍🏻点赞,你的认可是我创作的动力!

⭐收藏,你的青睐是我努力的方向!

✏️评论,你的意见是我进步的财富!

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

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

相关文章

Kotlin编程实战——类与对象(05)

一 概述 类与继承属性和字段接口(interface )函数式&#xff08;SAM&#xff09;接口可见性修饰符扩展数据类(data class)密封类泛型嵌套类与内部类枚举类对象表达式与对象声明类型别名内联类(inline class)委托委托属性 二 类与继承 类继承(open override )抽象类(abstract)…

MySQL去重中 distinct 和 group by 的区别

今天在写业务需要对数据库重复字段进行去重时&#xff0c;因为是去重&#xff0c;首先想到的是distinct关键字。于是一小时过去了。。。。&#xff08;菜鸟一个&#xff0c;大家轻点骂&#xff09; 我把问题的过程用sql语句演示给大家演示一下 首先我使用的是mybatis-plus&am…

数据结构之哈希表

文章目录 一、概念二、哈希冲突三、如何解决哈希冲突&#xff1f; 1.哈希函数设计2.负载因子调节3.闭散列4.开散列&#xff08;哈希桶&#xff09;四、模拟实现哈希桶总结一、概念 顺序结构以及平衡树中&#xff0c;元素与其存储位置之间没有对应的关系&#xff0c;因此在查找一…

C++多态学习笔记

C多态学习笔记一、多态概述二、多态的作用三、多态发生的三个条件四、多态实现的原理五、接口的定义六、模板方法模式七、虚析构函数和纯虚析构函数7.1 虚析构函数7.2 纯虚析构函数八、重写重载重定义九、父类引用子类对象一、多态概述 同一个操作作用于不同的对象&#xff0c;…

2014年848数据结构真题复习

求k频度K0; for&#xff08;i1;i<n;i&#xff09; 假如是1——8&#xff0c;执行了9次&#xff0c;8次有效&#xff0c;最后一次无效for&#xff08;ji;j<n;j&#xff09;k 我的理解&#xff1a;假设n为8我们看k频度实际上就是看内圈for的有效循环次数第一轮是1——8 八次…

基础算法 第七课——归并排序

文章目录导言归并排序的概念步骤说明逐步分析STEP1STEP2STEP3STEP4STEP5STEP6STEP0总结导言 这&#xff0c;是一篇现学现卖的文章。因为&#xff0c;我根本没学过归并排序。所以&#xff0c;这篇文章&#xff0c;绝对能让您学懂归并。如果不懂&#xff0c;那我就再学一遍&…

KVM Forum 2022应该关注的话题

1. QEMU 和 KVM 自动性能基准测试 QEMU & KVM Automated Performance Benchmarking SUSE - Dario Faggioli, SUSE SUSE正在开发一个框架&#xff0c;用于对虚拟化工作负载进行自动性能基准测试。它是围绕着MMTests&#xff08;已经在Linux内核社区使用了几年&#xff09;建…

2022-Java 后端工程师面试指南 -(SSM)

前言 种一棵树最好的时间是十年前&#xff0c;其次是现在 Tips 面试指南系列&#xff0c;很多情况下不会去深挖细节&#xff0c;是小六六以被面试者的角色去回顾知识的一种方式&#xff0c;所以我默认大部分的东西&#xff0c;作为面试官的你&#xff0c;肯定是懂的。 上面的…

Mybatis之foreach

文章目录一、foreach属性二、使用foreach批量删除(法一)1.接口2.mapper文件3.测试类4.运行结果三、使用foreach批量删除(法二)1.mapper文件四、使用foreach批量插入1.接口2.mapper文件3.测试类4.运行结果一、foreach属性 collection&#xff1a;指定数组或者集合 item&#xf…

FPGA时序约束01——基本概念

前言1. 越来越多的时序问题 随着FPGA时钟频率加快与其实现的逻辑功能越来越复杂&#xff0c;开发者遇到的问题很多时候不再是代码逻辑的问题&#xff0c;而是时序问题。一些开发者可能有这样的经历&#xff0c;一个模块在100MHz时钟运行没问题&#xff0c;而将时钟频率改为150…

【仿牛客网笔记】 Spring Boot进阶,开发社区核心功能-事务管理

添加评论中会用到事务管理。 解决的程度不同&#xff0c;层级不同。我们一般选择中间的级别。 选择时既能满足业务的需要&#xff0c;又能保证业务的安全性&#xff0c;在这样的前提下我们追求一个更高的性能。 第一类丢失更新 图中是没有事务隔离的情况 第二类丢失更新 脏…

需求工程方法的学习

作业要求&#xff1a;总结尽可能多的需求工程的方法和技术&#xff0c;要求归纳总结各种方法的适用场景、优缺点等。说明&#xff1a;其中需求工程包括需求获取、需求分析、规格说明、验证、管理等。只要是用于需求工程相关的技术和方法都可以算。 软件需求工程划分为需求开发…

Linux 中 man手册中函数后面括号数字释义

文章目录简介参考资料简介 Linux手册页项目记录了用户空间程序使用的Linux内核和C库接口。 用man手册查看系统命令&#xff0c;系统调用&#xff0c;glibc函数时&#xff0c;会发现其后面会有个括号&#xff0c;括号里面是一个数字&#xff0c;比如&#xff1a; access(2), …

一文了解Spring框架

目录 SpringBoot VS Servlet Spring是什么&#xff1f; loC&#xff1a;控制反转 DI 创建一个Spring项目 创建一个Spring IOC容器 注册Bean对象 获取Bean对象 注意事项&#xff1a; 类注解 为什么有这么多类注解&#xff1f; 注册与注入 方法注解 Bean Spr…

《R语言数据分析》2022-2023第一学期课程分析报告

1 (30分)基本操作题 1.1 (10分) 请写出下面问题的R代码 1.(2分)安装并加载gtools扩展包。 install.packages(“gtools”) library(gtools) 2.(2分)查看当前已经加载的所有包。 as.data.frame(installed.packages())$Package 3.(2分)查看gtools包的帮助网页。 ?gtools…

《清单革命》内容梳理随笔

《清单革命》内容梳理&随笔 起 书即是将四散的知识按照逻辑和网状联系编排起来。你应该这样去读&#xff0c;高屋建瓴、层次有秩、显得貌似自己有经验&#xff08;褒义&#xff09;的读&#xff0c;读出一些感想和方法论&#xff0c;无论是读出书里的还是书外的&#xff…

【MySQL高级】SQL优化

5. SQL优化 5.1 大批量插入数据 环境准备 &#xff1a; CREATE TABLE tb_user_2 (id int(11) NOT NULL AUTO_INCREMENT,username varchar(45) NOT NULL,password varchar(96) NOT NULL,name varchar(45) NOT NULL,birthday datetime DEFAULT NULL,sex char(1) DEFAULT NULL,…

【数据库】实验五 数据库综合查询|多表查询、聚集函数、orderby、groupby

文章目录参考文章本文在实验四的基础上增加了orderby、聚集函数、groupby、多表查询的知识点&#xff0c;相较于上一次实验的难度变大了&#xff0c;嵌套表达更多了&#xff0c;逐渐开始套娃…… 其实可以看成一个偏正短语来拆分&#xff0c;再写成SQL语句&#xff0c;比如查询…

微信小程序|基于小程序实现人脸数量检测

一、文章前言二、具体流程及准备三、开发步骤四、完整代码一、文章前言 此文主要通过小程序实现检测图片中的人脸数量并标记出位置信息。 当近视的小伙伴看不清远处的人时&#xff0c;用小程序一键识别就可以在手机上看清楚啦&#xff0c;是不是很实用呢。 典型应用场景&#x…

2022年还在做手动测试?是该好好反思了

为什么会写这篇文章呢&#xff1f;主要是前段时间有个朋友在QQ上和我交流&#xff0c;说他干了10年的手工测试了&#xff0c;现在还能不能转行。 说实话&#xff0c;当时我听完非常惊讶&#xff01;由此&#xff0c;我写了今天这篇文章。内容纯属个人观点&#xff0c;如果对你…