C_字符串的一些函数

1.字符串输入函数

scanf("%s",数组名);

gets(数组名);

区别:

scanf(“%s”,数组名);  把空格识别为输入结束

#include <stdio.h>int main()
{char a[10];printf("输入:");scanf("%s",a);//gets(a);printf("输出:%s\n",a);return 0;
}

gets(数组名);  可以识别空格字符到数组中

#include <stdio.h>int main()
{char a[10];printf("输入:");//scanf("%s",a);gets(a);printf("输出:%s\n",a);return 0;
}

2.字符串输出函数

printf(“xxxx%s”,数组名);

puts(数组名);

区别:

printf可以放描述语

puts函数自动加换行符

3.计算字符串有效长度函数

计算字符串长度可以使用标准库中的 strlen 函数。这个函数位于 <string.h> 头文件中。

#include <stdio.h>
#include <string.h>int main() 
{char str[] = "Hello, World!";size_t length = strlen(str);  // 计算字符串长度printf("Length of the string is: %zu\n", length);return 0;
}

sizeof   和  strlen 的区别?

sizeof:

属性 :是一个关键字

使用格式: int val = sizeof(变量名); 可以用于变量,数组

功能    :计算占用字节空间大小的

strlen:

属性 :是一个函数

使用格式: int val = strlen(数组名) ;只能用于数组(字符串)

功能    :计算字符串的有效长度

练习1:

char a[10] = “qwert”;

sizeof(a)    //10byte

strlen(a)    //5

练习2:

char a[] = “qwert”;

sizeof(a)    //6byte   

strlen(a)    //5

练习:自己写一个。

要求:

用户在主函数中输入一个字符串,

写一个子函数,子函数功能是接到主函数的字符串计算长度,并且返回具体长度值.

主函数调用子函数通过接收返回值来打印字符串的长度.

#include <stdio.h>int my_strlen(char *str);int main()
{char a[20];int len;printf("请输入一个字符串:\n");scanf("%s",a);len = my_strlen(a);printf("输入的字符串的长度为:%d",len);return 0;
}/*******************************************************
函数名     :my_strlen
函数功能   :计数字符串的有效长度
函数参数   :char *str
函数返回值 :int
函数描述   :
*******************************************************/
int my_strlen(char *str)
{int cont = 0;int i = 0;while(*(str+i) != '\0'){cont++;i++;}return cont;
}

4.字符串复制函数

复制字符串可以使用标准库中的 strcpy 函数。这个函数位于 <string.h> 头文件中。

#include <stdio.h>
#include <string.h>int main() {char src[] = "Hello, World!";char dest[50];  // 确保目标数组足够大strcpy(dest, src);  // 复制字符串printf("Source String: %s\n", src);printf("Destination String: %s\n", dest);return 0;
}

练习:自己写一个。

要求:

        用户输入两个字符串str1 和 str2

        要求写一个子函数将str2复制给str1

        打印复制后的str1

         char str1[] = “123456”;     

         char str2[] = “abcdef“;

        复制后:str1 : “abcdef“  

#include <stdio.h>void my_strcpy(char *dest,char *src);int main()
{char str1[50],str2[50];printf("请输入str1:");scanf("%s",str1);printf("请输入str2:");scanf("%s",str2);my_strcpy(str1,str2);printf("复制后的str1:%s",str1);return 0;
}/*******************************************************
函数名     :my_strcpy
函数功能   :复制字符串
函数参数   :char *dest char *src
函数返回值 :无
函数描述   :函数会将字符串src复制给dest
*******************************************************/
void my_strcpy(char *dest,char *src)
{int i = 0;while(*(src+i) != '\0'){*(dest+i) = *(src+i);i++;}*(dest+i) = '\0';       //这句非常重要,否则当str1和str2长度不一致时会出现bug
}

假如没有加这一句:

*(dest+i) = '\0';

当str2长, str1短,  复制后str1会出现乱码,因为结束字符被覆盖了;(有些编译器在执行时会优化,不会出现乱码)

当str1长, str2短,  复制后str1会没有完全被覆盖;

可以注释掉这一句看看会发生什么。

5.字符串拼接函数 

字符串拼接可以使用标准库中的 strcat 函数。这个函数位于 <string.h> 头文件中。

#include <stdio.h>
#include <string.h>int main() {char dest[50] = "Hello, ";  // 目标字符串,留出足够空间char src[] = "World!";// 使用 strcat 函数拼接字符串strcat(dest, src);printf("Concatenated String: %s\n", dest);return 0;
}

练习:自己写一个。

要求:

用户主函数中输入两个字符串str1和str2

写一个子函数实现将str2拼接到str1后面

str1:1234

str2:abcd

拼接后:str1:1234abcd

#include <stdio.h>void my_strcat(char *dest,char *src);int main()
{char str1[50],str2[50];printf("请输入str1:");scanf("%s",str1);printf("请输入str2:");scanf("%s",str2);my_strcat(str1,str2);printf("拼接后的str1:%s",str1);return 0;
}/*******************************************************
函数名     :my_strcat
函数功能   :拼接字符串
函数参数   :char *dest char *src
函数返回值 :无
函数描述   :函数会将字符串src拼接在dest后
*******************************************************/
void my_strcat(char *dest,char *src)
{int i = 0,j = 0;while(*(dest+i) != '\0'){i++;}while(*(src+j) != '\0'){*(dest+i) = *(src+j);i++;j++;}*(dest+i) = '\0';
}

6.字符串比较函数

字符串比较可以使用标准库中的 strcmp 函数。这个函数位于 <string.h> 头文件中。

#include <stdio.h>
#include <string.h>int main() {char str1[50], str2[50];printf("请输入第一个字符串: ");scanf("%s", str1);printf("请输入第二个字符串: ");scanf("%s", str2);int result = strcmp(str1, str2);if (result == 0) {printf("两个字符串相同。\n");} else if (result < 0) {printf("第一个字符串小于第二个字符串。\n");} else {printf("第一个字符串大于第二个字符串。\n");}return 0;
}

(库函数是从头开始逐个比较,只要出现不同的字符就立马返回结果) 

练习:自己写一个。

要求:

用户在主函数输入两个字符串,str1和str2,

在子函数中判断连个字符串是否相等,(长度要相等,对应字符一样)

相等返回0,不相等返回1;

(和库函数不太一样)

#include <stdio.h>int my_strcmp(char *str1,char *str2);int main()
{char str1[50],str2[50];int judge;printf("请输入str1:");scanf("%s",str1);printf("请输入str2:");scanf("%s",str2);judge = my_strcmp(str1,str2);if(judge == 0){printf("字符串str1和字符串str2相同。");}else if(judge == 1){printf("字符串str1和字符串str2不相同。");}return 0;
}/*******************************************************
函数名     :my_strcmp
函数功能   :比较字符串
函数参数   :char *str1 char *str2
函数返回值 :int
函数描述   :比较字符串str1和字符串str2,如果相同则返回0,不相同则返回1.(长度和内容都相同)
*******************************************************/
int my_strcmp(char *str1, char *str2)
{// 定义循环索引变量int i = 0, j = 0, k = 0;// 遍历第一个字符串,找到结束符'\0'的位置while (*(str1 + i) != '\0'){i++;  // 递增索引}// 遍历第二个字符串,找到结束符'\0'的位置while (*(str2 + j) != '\0'){j++;  // 递增索引}// 如果两个字符串的长度相同if (i == j){// 比较两个字符串的每一个字符while (*(str1 + k) != '\0'){// 如果某一位置的字符不同,返回1表示不相同if (*(str1 + k) != *(str2 + k)){return 1;  // 字符不同,返回1}k++;  // 继续比较下一个字符}return 0;  // 所有字符都相同,返回0}else  // 如果两个字符串的长度不同{return 1;  // 长度不同,返回1}
}

也可以这样写,这样比较像库函数的写法。

#include <stdio.h>int my_strcmp(char *str1, char *str2);int main()
{char str1[50], str2[50];int judge;printf("请输入str1: ");scanf("%s", str1);printf("请输入str2: ");scanf("%s", str2);judge = my_strcmp(str1, str2);if(judge == 0){printf("字符串str1和字符串str2相同。\n");}else{printf("字符串str1和字符串str2不相同。\n");}return 0;
}/*******************************************************
函数名     : my_strcmp
函数功能   : 比较字符串
函数参数   : char *str1, char *str2
函数返回值 : int
函数描述   : 比较字符串str1和字符串str2,如果相同则返回0,不相同则返回1。(长度和内容都相同)
*******************************************************/
int my_strcmp(char *str1, char *str2)
{while (*str1 != '\0' && *str2 != '\0')  // 同时遍历两个字符串{if (*str1 != *str2)  // 如果字符不相同,返回1{return 1;}str1++;str2++;}// 如果两个字符串长度不同,直接返回1if (*str1 != *str2){return 1;}// 如果完全遍历过后两个字符串都相同,返回0return 0;
}

这是库函数的写法:

int my_strcmp( char *str1, char *str2) {
    while (*str1 != '\0' && *str2 != '\0') {
        if (*str1 != *str2) {
            return *str1 - *str2;  // 返回字符差值
        }
        str1++;
        str2++;
    }
    
    // 如果字符串都已结束,则比较长度
    return *str1 - *str2;
}

一些小题目练练手

1.编写程序,将用户输入的字符串中的所有的字符a用*代替,然后输出。

分析:

通过循环结构遍历每个字符并且判断是否为子符a,

如果是字符a,用*字符替换此元素

循环的条件  用户输入的字符串不是'\0'

2.输入一串字符,把其中的大写字母变成小写字母并输出

分析:

用户输入一个字符串,

通过循环结构遍历每个字符,

判断如果某个字符是大写的就把此元素替换为对应的字符小写

循环条件是  '\0'

3.写一函数判断一字符串是否为回文,是返回1,不是返回0,

"123321"              

"12321"

"asdffdsa"  

"asdfdsa"

分析:

用第一个 与最后一个比较 ,以此类推, 如果出现不相等的就不是回文

循环结构正常结束,就是回文。


1.

#include <stdio.h>int main()
{char a[100];int i = 0;printf("请输入字符串:");scanf("%s",a);while(a[i] != '\0'){if(a[i] == 'a'){a[i] = '*';}i++;}printf("已经将所以'a'替换成了‘*’\n替换后的字符串为:%s",a);return 0;
}

2.

#include <stdio.h>int main()
{char a[100];int i = 0;printf("请输入字符串:");scanf("%s",a);while(a[i] != '\0'){if(a[i] >= 'A'&& a[i] <='Z'){a[i] += 32;}i++;}printf("已经将所以大写字母替换成对应的小写字母\n替换后的字符串为:%s",a);return 0;
}

3.

#include <stdio.h>
#include <string.h>int pal(char *str);int main()
{char a[100];int judge;printf("请输入字符串:");scanf("%s",a);judge = pal(a);if(judge == 1){printf("是回文");}else if(judge == 0){printf("不是回文");}return 0;
}int pal(char *str){int len = strlen(str);for(int i = 0 ;i < len/2;i++){if(*(str+i) != *(str+len-1-i)){return 0;}}return 1;}

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

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

相关文章

JavaScript实现tab栏切换

JavaScript实现tab栏切换 代码功能概述 这段代码实现了一个简单的选项卡&#xff08;Tab&#xff09;切换功能。它通过操作 HTML 元素的类名&#xff08;class&#xff09;来控制哪些选项卡&#xff08;Tab&#xff09;和对应的内容板块显示&#xff0c;哪些隐藏。基本思路是先…

《网络聊天室项目:全面分析测试报告》

目录 一、项目介绍二、项目功能三、测试计划1. 编写测试用例2. 实际执行测试的部分操作步骤3. 自动化测试 四、项目bug&#xff08;1&#xff09;bug描述&#xff08;2&#xff09;bug描述 五、项目总结 一、项目介绍 网络聊天室项目实现了一个网络交流平台&#xff0c;用户在w…

大数据新视界 -- 大数据大厂之 Hive 数据压缩:优化存储与传输的关键(上)(19/ 30)

&#x1f496;&#x1f496;&#x1f496;亲爱的朋友们&#xff0c;热烈欢迎你们来到 青云交的博客&#xff01;能与你们在此邂逅&#xff0c;我满心欢喜&#xff0c;深感无比荣幸。在这个瞬息万变的时代&#xff0c;我们每个人都在苦苦追寻一处能让心灵安然栖息的港湾。而 我的…

软通动力携子公司鸿湖万联、软通教育助阵首届鸿蒙生态大会成功举办

11月23日中国深圳&#xff0c;首届鸿蒙生态大会上&#xff0c;软通动力及软通动力子公司鸿湖万联作为全球智慧物联网联盟&#xff08;GIIC&#xff09;理事单位、鸿蒙生态服务&#xff08;深圳&#xff09;有限公司战略合作伙伴&#xff0c;联合软通教育深度参与了大会多项重磅…

动手学深度学习10.5. 多头注意力-笔记练习(PyTorch)

本节课程地址&#xff1a;多头注意力代码_哔哩哔哩_bilibili 本节教材地址&#xff1a;10.5. 多头注意力 — 动手学深度学习 2.0.0 documentation 本节开源代码&#xff1a;...>d2l-zh>pytorch>chapter_multilayer-perceptrons>multihead-attention.ipynb 多头注…

故障诊断 | Transformer-LSTM组合模型的故障诊断(Matlab)

效果一览 文章概述 故障诊断 | Transformer-LSTM组合模型的故障诊断(Matlab) 源码设计 %% 初始化 clear close all clc disp(此程序务必用2023b及其以上版本的MATLAB!否则会报错!) warning off %

用html+jq实现元素的拖动效果——js基础积累

用htmljq实现元素的拖动效果 效果图如下&#xff1a; 将【item10】拖动到【item1】前面 直接上代码&#xff1a; html部分 <ul id"sortableList"><li id"item1" class"w1" draggable"true">Item 1</li><li …

单片机学习笔记 12. 定时/计数器_定时

更多单片机学习笔记&#xff1a;单片机学习笔记 1. 点亮一个LED灯单片机学习笔记 2. LED灯闪烁单片机学习笔记 3. LED灯流水灯单片机学习笔记 4. 蜂鸣器滴~滴~滴~单片机学习笔记 5. 数码管静态显示单片机学习笔记 6. 数码管动态显示单片机学习笔记 7. 独立键盘单片机学习笔记 8…

计算机视觉硬件知识点整理六:工业相机选型

文章目录 前言一、工业数字相机的分类二、相机的主要参数三、工业数字摄像机主要接口类型四、选择工业相机的考量因素六、实例分析 前言 随着科技的不断进步&#xff0c;工业自动化领域正经历着前所未有的变革。作为工业自动化的重要组成部分&#xff0c;工业相机在工业检测、…

如何使用brew安装phpredis扩展?

如何使用brew安装phpredis扩展&#xff1f; phpredis扩展是一个用于PHP语言的Redis客户端扩展&#xff0c;它提供了一组PHP函数&#xff0c;用于与Redis服务器进行交互。 1、cd到php某一版本的bin下 /usr/local/opt/php8.1/bin 2、下载 phpredis git clone https://githu…

硬件看门狗工作原理

硬件看门狗是什么&#xff1f; 硬件看门狗&#xff08;Hardware Watchdog&#xff09;是一种用于监控系统运行状态的硬件设备或电路。它的主要功能是检测系统是否正常运行&#xff0c;并在系统出现故障或无响应时自动重启或采取其他恢复措施。 工作原理与引脚 硬件看门狗一般…

Linux -初识 与基础指令1

博客主页&#xff1a;【夜泉_ly】 本文专栏&#xff1a;【Linux】 欢迎点赞&#x1f44d;收藏⭐关注❤️ 文章目录 &#x1f4da; 前言&#x1f5a5;️ 初识&#x1f510; 登录 root用户&#x1f465; 两种用户➕ 添加用户&#x1f9d1;‍&#x1f4bb; 登录 普通用户⚙️ 常见…

Elasticsearch在liunx 中单机部署

下载配置 1、下载 官网下载地址 2、上传解压 tar -zxvf elasticsearch-XXX.tar.gz 3、新建组和用户 &#xff08;elasticsearch 默认不允许root账户&#xff09; #创建组 es groupadd es #新建用户 useradd ryzhang -g es 4、更改文件夹的用户权限 chown -R ryzhang …

Refit 使用详解

Git官网&#xff1a;https://github.com/reactiveui/refit Refit 是一个针对 .NET 应用程序的 REST API 客户端库&#xff0c;它通过接口定义 API 调用&#xff0c;从而简化与 RESTful 服务的交互。其核心理念是利用声明性编程的方式来创建 HttpClient 客户端&#xff0c;使得…

Ubuntu24.04配置DINO-Tracker

一、引言 记录 Ubuntu 配置的第一个代码过程 二、更改conda虚拟环境的默认安装路径 鉴于不久前由于磁盘空间不足引发的重装系统的惨痛经历&#xff0c;在新系统装好后当然要先更改虚拟环境的默认安装路径。 输入指令&#xff1a; conda info可能因为我原本就没有把 Anacod…

vulnhub靶场【哈利波特】三部曲之Aragog

前言 使用virtual box虚拟机 靶机&#xff1a;Aragog : 192.168.1.101 攻击&#xff1a;kali : 192.168.1.16 主机发现 使用arp-scan -l扫描&#xff0c;在同一虚拟网卡下 信息收集 使用nmap扫描 发现22端口SSH服务&#xff0c;openssh 80端口HTTP服务&#xff0c;Apach…

顶刊算法 | 鱼鹰算法OOA-BiTCN-BiGRU-Attention多输入单输出回归预测(Maltab)

顶刊算法 | 鱼鹰算法OOA-BiTCN-BiGRU-Attention多输入单输出回归预测&#xff08;Maltab&#xff09; 目录 顶刊算法 | 鱼鹰算法OOA-BiTCN-BiGRU-Attention多输入单输出回归预测&#xff08;Maltab&#xff09;效果一览基本介绍程序设计参考资料 效果一览 基本介绍 1.Matlab实…

getchar()

getchar():从计算机终端&#xff08;一般是键盘&#xff09;输入一个字符 1、getchar返回的是字符的ASCII码值&#xff08;整数&#xff09;。 2、getchar在读取结束或者失败的时候&#xff0c;会返回EOF 输入密码并确认&#xff1a; scanf读取\n之前的内容即12345678 回车符…

动态规划-----路径问题

动态规划-----路径问题 下降最小路径和1&#xff1a;状态表示2&#xff1a;状态转移方程3 初始化4 填表顺序5 返回值6 代码实现 总结&#xff1a; 下降最小路径和 1&#xff1a;状态表示 假设&#xff1a;用dp[i][j]表示&#xff1a;到达[i,j]的最小路径 2&#xff1a;状态转…

实现PDF文档加密,访问需要密码

01. 背景 今天下午老板神秘兮兮的来问我&#xff0c;能不能做个文档加密功能&#xff0c;就是那种用户下载打开需要密码才能打开的那种效果。boss都发话了&#xff0c;那必须可以。 需求&#xff1a;将 pdf 文档经过加密处理&#xff0c;客户下载pdf文档&#xff0c;打开文档需…