热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

去掉数组中的空值_C语言字符数组的定义与初始化!这里是重点圈起来,要考!...

1、字符数组的定义与初始化字符数组的初始化,最容易理解的方式就是逐个字符赋给数组中各元素。charstr[10]{I,,a,m,,‘h’,a,p,p,y};即把10个
4023b503823d9538a57e906cbda478b9.png

1、字符数组的定义与初始化

字符数组的初始化,最容易理解的方式就是逐个字符赋给数组中各元素。

char str[10]={ 'I',' ','a','m',' ',‘h’,'a','p','p','y'};

即把10个字符分别赋给str[0]到str[9]10个元素

如果花括号中提供的字符个数大于数组长度,则按语法错误处理;若小于数组

长度,则只将这些字符数组中前面那些元素,其余的元素自动定为空字符(即

'0' )。

2、字符数组与字符串

在c 语言中,将字符串作为字符数组来处理。(c++中不是)

在实际应用中人们关心的是有效字符串的长度而不是字符数组的长度,例如,

定义一个字符数组长度为100,而实际有效字符只有40个,为了测定字符串的实

际长度,C 语言规定了一个“字符串结束标志”,以字符'0’代表。如果有一个字

符串,其中第10个字符为'0',则此字符串的有效字符为9个。也就是说,在遇到

第一个字符'0'时,表示字符串结束,由它前面的字符组成字符串。

系统对字符串常量也自动加一个'0'作为结束符。例如"C Program”共有9个字

符,但在内存中占10个字节,最后一个字节'0'是系统自动加上的。(通过sizeof()

函数可验证)

有了结束标志'0'后,字符数组的长度就显得不那么重要了,在程序中往往依靠

检测'0'的位置来判定字符串是否结束,而不是根据数组的长度来决定字符串长

度。当然,在定义字符数组时应估计实际字符串长度,保证数组长度始终大于

字符串实际长度。(在实际字符串定义中,常常并不指定数组长度,如char str[ ])

说明:'n’代表ASCII 码为0的字符,从ASCII 码表中可以查到ASCII 码为0的

字符不是一个可以显示的字符,而是一个“空操作符”,即它什么也不干。用它

来作为字符串结束标志不会产生附加的操作或增加有效字符,只起一个供辨别

的标志。

对C 语言处理字符串的方法由以上的了解后,再对字符数组初始化的方法补充

一种方法——即可以用字符串常量来初始化字符数组:

char str[ ]={"I am happy"}; 可以省略花括号,如下所示

char str[ ]="I am happy";

注意:上述这种字符数组的整体赋值只能在字符数组初始化时使用,不能用于

字符数组的赋值,字符数组的赋值只能对其元素一一赋值,下面的赋值方法是

错误的

char str[ ];

str="I am happy";

不是用单个字符作为初值,而是用一个字符串(注意:字符串的两端是用双引

号“”而不是单引号‘’括起来的)作为初值。显然,这种方法更直观方便。(注意:

数组str 的长度不是10,而是11,这点请务必记住,因为字符串常量"I am happy"

的最后由系统自动加上一个'0')

因此,上面的初始化与下面的初始化等价

char str[ ]={'I',' ','a','m',' ','h','a','p','p','y','0'};

而不与下面的等价

char str[ ]={'I',' ','a','m',' ','h','a','p','p','y'};

前者的长度是11,后者的长度是10.

说明:字符数组并不要求它的最后一个字符为'0',甚至可以不包含'0',向下面

这样写是完全合法的。

char str[5]={'C','h','i','n','a'};

++++++++

可见,用两种不同方法初始化字符数组后得到的数组长度是不同的。

#include

void main(void)

{

char c1[]={'I',' ','a','m',' ','h','a','p','p','y'};

char c2[]="I am happy";

int i1=sizeof(c1);

int i2=sizeof(c2);

printf("%dn",i1);

printf("%dn",i2);

}

结果:10 11

3、字符串的表示形式

在C 语言中,可以用两种方法表示和存放字符串:

(1)用字符数组存放一个字符串

char str[ ]="I love China";

(2)用字符指针指向一个字符串

char* str="I love China";

对于第二种表示方法,有人认为str 是一个字符串变量,以为定义时把字符串常

量"I love China"直接赋给该字符串变量,这是不对的。

C 语言对字符串常量是按字符数组处理的,在内存中开辟了一个字符数组用来存

放字符串常量,程序在定义字符串指针变量str 时只是把字符串首地址(即存放

字符串的字符数组的首地址)赋给str。

两种表示方式的字符串输出都用

printf("%sn",str);

%s 表示输出一个字符串,给出字符指针变量名str(对于第一种表示方法,字

符数组名即是字符数组的首地址,与第二种中的指针意义是一致的),则系统先

输出它所指向的一个字符数据,然后自动使str 自动加1,使之指向下一个字符...,

如此,直到遇到字符串结束标识符" 0 "。

4、对使用字符指针变量和字符数组两种方法表示字符串的讨论

虽然用字符数组和字符指针变量都能实现字符串的存储和运算,但它们二者之

间是有区别的,不应混为一谈。

4.1、字符数组由若干个元素组成,每个元素放一个字符;而字符指针变量中存

放的是地址(字符串/字符数组的首地址),绝不是将字符串放到字符指针变量中

(是字符串首地址)

4.2、赋值方式:

对字符数组只能对各个元素赋值,不能用以下方法对字符数组赋值

char str[14];

str="I love China"; (但在字符数组初始化时可以,即char

str[14]="I love China";)

而对字符指针变量,采用下面方法赋值:

char* a;

a="I love China";

或者是char* a="I love China"; 都可以

4.3、对字符指针变量赋初值(初始化):

char* a="I love China";

等价于:

char* a;

a="I love China";

而对于字符数组的初始化

char str[14]="I love China";

不能等价于:

char str[14];

str="I love China"; (这种不是初始化,而是赋值,而对数组这样赋

值是不对的)

4.4、如果定义了一个字符数组,那么它有确定的内存地址;而定义一个字符指

针变量时,它并未指向某个确定的字符数据,并且可以多次赋值。

5、字符串处理函数

5.1

char *strcat(char *str1,const char *2 );

char *strcat(char *strDestination,const char *strSource );

功能:函数将字符串str2 连接到str1的末端,并返回指针str1

注:连接前两个字符串的后面都有一个' 0 ',连接时将字符串1后面的' 0 ‘去掉,

只在新串最后保留一个' 0 ‘

5.2

char *strcpy(char *str1,const char *2 );

char *strcpy(char *strDestination,const char *strSource );

功能:复制字符串strSource 中的字符到字符串strDestination,包括空值结

束符。返回值为指针strDestination。

注:1、“字符数组1”必须写成数组名形式,“字符串2"可以是字符数组名,也可

以是一个字符串常量

2、复制时连同字符串后面的' 0 ' 一起复制到数组1中

3、不能用赋值语句直接将一个字符串常量或者字符数组直接赋给一个

字符数组(同普通变量数组是一样的),而只能用strcpy 函数处理。

4、可以用strcpy 函数将字符串2中的前若干个字符复制到字符数组1

中去。

如果你也想成为一名程序员那就关注我与我交流,不管是零基础还是入门小白学习从来不是一个人的事情,要有个相互监督的伙伴,工作需要学习C/C++或者感兴趣、为了入行、转行学习C/C++的伙伴可以一起学习!关注小编的专栏,每晚技术大牛手把手教你如何实现!

程序猿​zhuanlan.zhihu.com
8315fbd9f28f02efba00f3face2a11fa.png



推荐阅读
  • 本文介绍了P1651题目的描述和要求,以及计算能搭建的塔的最大高度的方法。通过动态规划和状压技术,将问题转化为求解差值的问题,并定义了相应的状态。最终得出了计算最大高度的解法。 ... [详细]
  • Iamtryingtomakeaclassthatwillreadatextfileofnamesintoanarray,thenreturnthatarra ... [详细]
  • 本文主要解析了Open judge C16H问题中涉及到的Magical Balls的快速幂和逆元算法,并给出了问题的解析和解决方法。详细介绍了问题的背景和规则,并给出了相应的算法解析和实现步骤。通过本文的解析,读者可以更好地理解和解决Open judge C16H问题中的Magical Balls部分。 ... [详细]
  • 本文讨论了使用差分约束系统求解House Man跳跃问题的思路与方法。给定一组不同高度,要求从最低点跳跃到最高点,每次跳跃的距离不超过D,并且不能改变给定的顺序。通过建立差分约束系统,将问题转化为图的建立和查询距离的问题。文章详细介绍了建立约束条件的方法,并使用SPFA算法判环并输出结果。同时还讨论了建边方向和跳跃顺序的关系。 ... [详细]
  • c语言\n不换行,c语言printf不换行
    本文目录一览:1、C语言不换行输入2、c语言的 ... [详细]
  • 本文介绍了UVALive6575题目Odd and Even Zeroes的解法,使用了数位dp和找规律的方法。阶乘的定义和性质被介绍,并给出了一些例子。其中,部分阶乘的尾零个数为奇数,部分为偶数。 ... [详细]
  • Linux环境变量函数getenv、putenv、setenv和unsetenv详解
    本文详细解释了Linux中的环境变量函数getenv、putenv、setenv和unsetenv的用法和功能。通过使用这些函数,可以获取、设置和删除环境变量的值。同时给出了相应的函数原型、参数说明和返回值。通过示例代码演示了如何使用getenv函数获取环境变量的值,并打印出来。 ... [详细]
  • 本文介绍了一个题目的解法,通过二分答案来解决问题,但困难在于如何进行检查。文章提供了一种逃逸方式,通过移动最慢的宿管来锁门时跑到更居中的位置,从而使所有合格的寝室都居中。文章还提到可以分开判断两边的情况,并使用前缀和的方式来求出在任意时刻能够到达宿管即将锁门的寝室的人数。最后,文章提到可以改成O(n)的直接枚举来解决问题。 ... [详细]
  • 本文讨论了一个数列求和问题,该数列按照一定规律生成。通过观察数列的规律,我们可以得出求解该问题的算法。具体算法为计算前n项i*f[i]的和,其中f[i]表示数列中有i个数字。根据参考的思路,我们可以将算法的时间复杂度控制在O(n),即计算到5e5即可满足1e9的要求。 ... [详细]
  • 如何在跨函数中使用内存?
    本文介绍了在跨函数中使用内存的方法,包括使用指针变量、动态分配内存和静态分配内存的区别。通过示例代码说明了如何正确地在不同函数中使用内存,并提醒程序员在使用动态分配内存时要手动释放内存,以防止内存泄漏。 ... [详细]
  • Java容器中的compareto方法排序原理解析
    本文从源码解析Java容器中的compareto方法的排序原理,讲解了在使用数组存储数据时的限制以及存储效率的问题。同时提到了Redis的五大数据结构和list、set等知识点,回忆了作者大学时代的Java学习经历。文章以作者做的思维导图作为目录,展示了整个讲解过程。 ... [详细]
  • 本文介绍了九度OnlineJudge中的1002题目“Grading”的解决方法。该题目要求设计一个公平的评分过程,将每个考题分配给3个独立的专家,如果他们的评分不一致,则需要请一位裁判做出最终决定。文章详细描述了评分规则,并给出了解决该问题的程序。 ... [详细]
  • 本文介绍了C++中省略号类型和参数个数不确定函数参数的使用方法,并提供了一个范例。通过宏定义的方式,可以方便地处理不定参数的情况。文章中给出了具体的代码实现,并对代码进行了解释和说明。这对于需要处理不定参数的情况的程序员来说,是一个很有用的参考资料。 ... [详细]
  • 本文介绍了OC学习笔记中的@property和@synthesize,包括属性的定义和合成的使用方法。通过示例代码详细讲解了@property和@synthesize的作用和用法。 ... [详细]
  • 李逍遥寻找仙药的迷阵之旅
    本文讲述了少年李逍遥为了救治婶婶的病情,前往仙灵岛寻找仙药的故事。他需要穿越一个由M×N个方格组成的迷阵,有些方格内有怪物,有些方格是安全的。李逍遥需要避开有怪物的方格,并经过最少的方格,找到仙药。在寻找的过程中,他还会遇到神秘人物。本文提供了一个迷阵样例及李逍遥找到仙药的路线。 ... [详细]
author-avatar
mobiledu2502902523
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有