之前我们学习数据类型的时候,有一个类型 char ,这个类型允许我们在里边放一个字符

char variable1='o';

char variable2='k';

#include <iostream>
using namespace std; int main(){
//C++当中字符数组赋值,''单引号中不能为空
char talk[]={'I',' ','a','m',' ','h','a','p','p','y'};
for(int i=;i<;i++){
cout<<talk[i];
}
cout<<endl;
}

使用字符二维数组制作输出一个钻石图形。

#include <iostream>
using namespace std; int main(){
//C++当中字符数组赋值,''单引号中不能为空
char talk[][]={{' ',' ','*'},
{' ','*',' ',' ','*'},
{'*',' ',' ',' ','*'},
{' ','*',' ','*'},
{' ',' ','*'}};
for(int i=;i<;i++){
for(int j=;j<;j++)
cout<<talk[i][j];
cout<<endl;
}
cout<<endl;
}
这个字符数组的长度是多少?
char talk[10]={'I',' ','a','m',' ','h','a','p','p','y'};
字符串 I am happy
string talk="I am happy";
两者意义上市一致的,但是长度上是不一致的。c++在字符y的后边自动添加了一个'\0',这个一个符号,表示字符串的结束。
string 和我们之前学的int float double boolean char 基本数据类型不同,可以直接在c++程序中使用。
string 是不能在c++中直接使用。
#include <iostream>
#include <string>
using namespace std; int main(){
int a=;
cout<<a;
//s的长度是多少呢? 是11 c++在字符串使用的时候自动添加了一个'\0'
//,当c++系统输出字符串的时候检测到 '\0',结束
string s="I am happy";
//arr的长度是多少呢? 是11
char arr[]="I am happy";
//arr2的长度是多少呢?是10
char arr2[]={'I',' ','a','m',' ','h','a','p','p','y','\0'};
//arr与arr2 是等价的
cout<<endl<<arr;
cout<<endl<<arr2;
cout<<endl;
cout<<s;
return ;
}

char str[5];

cin>>str;

如果输入字符串为Beijing字符串长度超出,也不会报错,(与其他数据类型不同)但是会破坏其他空间中的数据,有可能引发问题。


使用字符串处理函数,进行字符串的操作

第一个,字符串连接

使用strcat(char[],const char[])

举例:

#include <iostream>
#include <string.h>
using namespace std; int main(){
//C++当中字符数组赋值,''单引号中不能为空
char str1[]="People's Republic of ";
char str2[]="China";
cout<<strcat(str1,str2); }

第二个,字符串复制

#include <iostream>
#include <string.h>
using namespace std; int main(){
//C++当中字符数组赋值,''单引号中不能为空
char str1[];
char str2[]="China";
strcpy(str1,str2);
cout<<str1<<" ~ "<<str2; }

第三个,字符串比较

#include <iostream>
#include <string.h>
using namespace std; int main(){
//按照字母表的顺序,在后边就大 ASCII
char str1[]="Zoa";
char str2[]="Zoble";
int x=strcmp(str1,str2);
cout<<x; }

如果相等为0,如果大于为1,如果小于为-1;

第四个,字符串长度函数

#include <iostream>
#include <string.h>
using namespace std; int main(){
//字符串"Zoa",实际上等价于{'Z','o','a','\0'}
//字符串长度函数 求的值是实际长度,不是真实长度
char str1[]="Zoa";
char str2[]="Zoble";
int x=strlen(str1);
int y=strlen(str2);
cout<<x<<"~~~"<<y; }

字符数组函数,连接strcat 复制函数strcpy 比较函数strcmp 长度函数 strlen的更多相关文章

  1. C语言字符数组超细讲解

    看到标题,有不少朋友会想:字符数组不也是数组吗?为什么要单独拿出来讲哩?莫非它是朵奇葩? 哈哈,确实,一起来认识一下这朵数组界的奇葩吧! 一.字符数组的定义.引用.初始化 大家好!我是字符数组,看我的 ...

  2. String类,StringBuffer类转字符数组

    String不可变类型和StringBuffer可变类型 String类和StringBuffer类都是字符串表示类,区别在于String对象引用变量是不可变的,而StringBuffer类对象引用变 ...

  3. c字符和字符数组/字符串

    一维和二维的都可以:一维的情况如下:1,char string0[10];2,char string1[]="prison break";3,char string2[100]=& ...

  4. 转:C语言字符串操作函数 - strcpy、strcmp、strcat、反转、回文

    转自:C语言字符串操作函数 - strcpy.strcmp.strcat.反转.回文 C++常用库函数atoi,itoa,strcpy,strcmp的实现 作者:jcsu C语言字符串操作函数 1. ...

  5. C:函数:功能:实现字符数组中所有字母的倒序存放并输出

    前两天小测碰到一道题,建立一个函数,功能:实现字符数组中所有字母的倒序存放并输出,一开始觉得简单跟数字数组差不多,运行一下发现很多格式错误,这些是不必要的错误,现在就来说下,先说一下代码思路:定义一个 ...

  6. 已知一个字符串S 以及长度为n的字符数组a,编写一个函数,统计a中每个字符在字符串中的出现次数

    import java.util.Scanner; /** * @author:(LiberHome) * @date:Created in 2019/3/6 21:04 * @description ...

  7. 二维字符数组利用gets()函数输入

    举例: ][]; ;i<;i++) gets(a[i]); a是二维字符数组的数组名,相当于一维数组的指针, 所以a[i]就相当于指向第i个数组的指针,类型就相当于char *,相当于字符串.

  8. 字符串函数(strcpy字符串拷,strcmp字符串比较,strstr字符串查找,strDelChar字符串删除字符,strrev字符串反序,memmove拷贝内存块,strlen字符串长度)

    1.strcpy字符串拷贝拷贝pStrSource到pStrDest,并返回pStrDest地址(源和目标位置重叠情况除外) char *strcpy(char *pStrDest, const ch ...

  9. C语言中的字符串拷贝函数strcpy和内存拷贝函数memcpy的区别与实现

    strcpy和memcpy都是标准C库函数,它们有下面的特点. strcpy提供了字符串的复制.即strcpy只用于字符串复制,并且它不仅复制字符串内容之外,还会复制字符串的结束符'\0'. 已知st ...

随机推荐

  1. 基于 Algebird 谈一谈代数数据类型在数据聚合中的应用

    此文已由作者肖乃同授权网易云社区发布. 欢迎访问网易云社区,了解更多网易技术产品运营经验. 代数数据类型是指满足一定数学特性的数据类型, 这些特性使得计算能够很方便的并行化,在Scalding和  S ...

  2. PCB 线路铜皮面积(残铜率)计算的实现方法

    一个多月没更新博客园了,这里继续分享关于PCB工程相关一些知识,做过PCB工程都知道用使用genesis或incam是可以非常方便的计算得到铜皮面积这个参数[下图],但实际这个软件是通过什么算法计算出 ...

  3. TP3.2单字母函数

    A方法 A方法用于在内部实例化控制器 调用格式:A(‘[项目://][分组/]模块’,’控制器层名称’) 最简单的用法: $User = A('User'); 表示实例化当前项目的UserAction ...

  4. hdoj1540 【线段树的表示】

    大牛blog 这题的题解写给自己看-- 总结(瞎扯一点): 之前只会思考,len,sum,然后GG,如果只是sum和len的去用的话,就是在mid的时候会GG.然后这次也是参考大牛的写法,其实还是蛮简 ...

  5. poj 3683 Priest John's Busiest Day【2-SAT+tarjan+拓扑】

    转换成2-SAT模型,建边是如果时间(i,j)冲突就连边(i,j'),其他同理 tarjan缩点,判可行性 返图拓扑,输出方案 #include<iostream> #include< ...

  6. Contest Hunter 0103最短Hamilton路径 【状压dp】 By cellur925

    题目传送门 Hamilton路径的定义:从0(起点)到n-1(终点)不重不漏地经过每个点恰好一次. 由于数据范围非常小,考虑状压.如NOIP2017宝藏一题,把状态压缩设为n个点是否已到达的二进制数. ...

  7. wordpress数据库结构及表说明

    数据表结构: wp_commentmeta:存储评论的元数据wp_comments:存储评论wp_links:存储友情链接(Blogroll)wp_options:存储WordPress系统选项和插件 ...

  8. ssh公私密钥的生成

    ssh密钥的生成 root账号密钥的生成: 这里我们切换到root账号下,执行ssh-keygen命令: ssh-keygen -t dsa 然后一路回车即可 """ [ ...

  9. bzoj1024 [SCOI2009]生日快乐【dfs】

    传送门:http://www.lydsy.com/JudgeOnline/problem.php?id=1024 普通的深搜. #include <cstdio> #include < ...

  10. dubbo中Hessian方法重载问题处理

    dubbo中Hessian方法重载,报出如下错误信息: 十一月 , :: 下午 org.apache.catalina.core.StandardWrapperValve invoke 严重: Ser ...