数组(一)——数组的声明、初始化及其简单处理

描述:
eg1.数组的声明和初始化
eg2.数组长度计算
eg3.字符串简单处理:拷贝,拼接,比较
eg4.在一个字符串中从末尾查找某个字符

1.数组的声明和初始化

//数组中元素的类型 数组名[数组元素个数]
typeName arrayName[arraySize];
    //初始化时不初始化数组大小
    int un_arr[]={1,2,3,4};//int类型
    char un_str0[]={'h','e','l','l','o','\0'};//字符串常量
    char un_str1[]="helloword"; //字符串常量
    char un_str2[]={'h','e','l','l','o'};//char 类型的数组

    //初始化时同时初始化数组的大小
    int arr[10]={1,2,3,4};//int类型 参数数组
    char str0[10]={'h','e','l','l','o','\0'};//字符串常量
    char str1[10]="helloword"; //字符串常量
    char str2[10]={'h','e','l','l','o'};//char 类型的数组
...

2.字符串常量的拼接,拷贝与比较

需要添加头文件

#include<cstring>

所使用的函数

strcpy(str1,str2)//将str2拷贝到str1
int flag=strcmp(str1,str2);//flag=0:两个字符串相等,flag>0:str1>str2,flag<0:str1<str2
strcat(str1,str2);//将str2拼接到str1的末尾

3.数组长度计算

需要添加头文件

#include<cstring>

所使用的函数

strlen(str1);//计算字符串的长度
int len=sizeof(arr)/sizeof(arr[0]);//计算整个数组的长度=数组所占字节数/单个元素字节数

4.在一个字符串中从末尾查找某个字符

在一个字符串中从末尾查找某个字符,当第一次查找到时,返回该字符到字符串末尾的子字符串,可用于从文件路径中读取文件名。

需要添加头文件

#include<cstring>

所使用的函数

char ch;
char* ptr=strrchr(str,ch)

代码示例

#include<iostream>
#include<cstring>

using namespace std;

int main()
{
    //eg1.初始化
    cout<<"\033[44meg1.Initializing.....\033[0m"<<endl;//为打印信息设置蓝色背景
    //初始化时不初始化数组大小
    int un_arr[]={1,2,3,4};//int类型
    char un_str0[]={'h','e','l','l','o','\0'};//字符串常量
    char un_str1[]="word"; //字符串常量
    char un_str2[]={'h','e','l','l','o'};//char 类型的数组

    //初始化时同时初始化数组的大小
    int arr[10]={1,2,3,4};//int类型 参数数组
    char str0[10]={'h','e','l','l','o','\0'};//字符串常量
    char str1[10]="word"; //字符串常量
    char str2[10]={'h','e','l','l','o'};//char 类型的数组
    cout<<"\033[44meg1 DONE!\033[0m"<<endl<<endl;//为打印信息设置蓝色背景

    //eg2.长度计算
    cout<<"\033[44meg1.Computing the length of array.....\033[0m"<<endl;//为打印信息设置蓝色背景
    cout<<"\033[3m\033[31mCompute size of the array with not initializing the length: \033[0m\033[0m"<<endl;//红色倾斜打印
    int un_arr_len = sizeof(un_arr)/sizeof(un_arr[0]);//由于初始化时没有定义数组的长度,所以此时得到的数组长度即数组中元素的个数
    cout<<"un_arr_len="<<un_arr_len<<endl;
    int un_str0_len = strlen(un_str0);
    cout<<"un_str0_len="<<un_str0_len<<endl;
    int un_str1_len = strlen(un_str1);
    cout<<"un_str1_len="<<un_str1_len<<endl;
    int un_str2_len = strlen(un_str2);
    cout<<"un_str2_len="<<un_str2_len<<endl;

    cout<<"\033[3m\033[31mCompute size of the array with initializing the length: \33[0m\33[0m"<<endl;//红色倾斜打印
    int arr_len = sizeof(arr)/sizeof(arr[0]);//此时计算的实际上是数组长度,而不是数组中元素的个数
    cout<<"arr_len="<<arr_len<<endl;
    int str0_len = strlen(str0);
    cout<<"str0_len="<<str0_len<<endl;
    int str1_len = strlen(str1);
    cout<<"str1_len="<<str1_len<<endl;
    int str2_len = strlen(str2);
    cout<<"str2_len="<<str2_len<<endl;
    cout<<"\033[44meg2 DONE!\033[0m"<<endl<<endl;//为打印信息设置蓝色背景

    //eg3.字符串简单处理:拷贝,拼接,比较
    cout<<"\033[44meg3.String process...\033[0m"<<endl;//为打印信息设置蓝色背景
    int Asize=str0_len+str1_len;
    char str3[Asize];
    strcpy(str3,str0);//字符串拷贝
    cout<<"str3="<<str3<<endl;
    int flag=strcmp(str3,str0);//字符串比较
    cout<<"the compare flag is "<<flag<<endl;//返回值为0则说明两个字符串相等
    strcat(str3,str1);
    cout<<"after function strcat(), str3="<<str3<<endl;
    cout<<"\033[44meg3 DONE!\033[0m"<<endl<<endl;//为打印信息设置蓝色背景
    
    //eg4.在一个字符串中从末尾查找某个字符,
    //当第一次查找到时,返回该字符到字符串末尾的子字符串,
    //可用于从文件路径中读取文件名
    cout<<"\033[44meg4.Finding str_two in str_one and return index...\033[0m"<<endl;//为打印信息设置蓝色背景
    char str4[]="/home/Linux/code/test.txt";
    char *ptr=strrchr(str4,'/');
    cout<<"file name is "<<ptr+1<<endl;
    cout<<"\033[44meg4 DONE!\033[0m"<<endl<<endl;//为打印信息设置蓝色背景
    return 0;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值