【C语言基础考研向】11 gets函数与puts函数及str系列字符串操作函数

2024-01-22 05:12

本文主要是介绍【C语言基础考研向】11 gets函数与puts函数及str系列字符串操作函数,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1.gets函数与puts函数

gets函数类似于scanf函数,用于读取标准输入.前面我们已经知道scanf函数在读取字符串时遇到空格就认为读取结束,所以当输入的字符串存在空格时,我们需要使用gets 函数进行读取.
gets函数的格式如下:

char *gets(char *str);

gets函数从STDIN (标准输入)读取字符并把它们加载到str(字符串)中,直到遇到换行符(\n) .如下例所示,执行后,我们输入"how are you",共11个字符,可以看到gets 会读取空格,同时可以看到我们并未给数组进行初始化赋值,但是最后有’\0’,这是因为gets遇到\n后,不会存储\n,而是将其翻译为空字符’\0’.

puts函数类似于printf函数,用于输出标准输出.puts函数的格式如下:

int puts(char *str);

函数 puts把 str(字符串)写入STDOU(标准输出). puts会将数组c中存储的"how are you"字符串打印到屏幕上,同时打印换行,相对于printf函数, puts只能用于输出字符串,同时多打印一个换行符,等价于printf(%sin",c).

#include <stdio.h>
//gets一次读取一行
int main()
{char c[20l;gets(c);puts(c);return 0;
}

执行结果如图:

how are you
how are you

2 str系列字符串操作函数(初试没那么重要,对于机试更重要一些)

str系列字符串操作函数主要包括strlen. strcpy. strcmp、strcat等. strlen函数用于统计字符串长度, strcpy函数用于将某个字符串复制到字符数组中, strcmp函数用于比较两个字符串的大小,strcat 函数用于将两个字符串连接到一起.各个函数的具体格式如下所示:

#include <string.h>
size_t strlen(char *str);
char *strcpy(char *to, const char *from);
int strcmp(const char *str1, const char *str2);
char *strcat(char *str1, const char *str2);

对于传参类型char*,直接放入字符数组的数组名即可.
接下来我们通过下例来具体学习str系列字符串操作函数,掌握每个函数的内部实现.

【例】str系列字符串操作函数的使用.

#include <stdlo.h>
#include <string.h>int mystrlen(char c[]){
int i = O;
while (c[i++]);
return i -1;}/ / strlen统计字符串长度
int main() {
int len;//用于存储字符串长度
char c[20];
char d[100] = "world";
gets(c);
puts(c);
len = strlen(c);
printf("len=%d\n",len);
len = mystrlen(c);
printf( "mystrlen len=%din", len);
strcat(c, d);
strcpy(d, c);//c中的字符串复制给d
puts(d);
printf("c?d %din", strcmp(c, d));
puts(c);
return O;
}

下图所示为我们输入"hello"后的执行结果,通过strlen 函数计算的字符串长度为5,我们自己写的函数就是strlen函数的计算原理,即通过判断结束符来确定字符串的长度.

strcpy函数用来将字符串中的字符逐个地赋值给目标字符数组.例中我们将c复制给d,就是将c中的每个字符依次赋值给d,也会将结束符赋值给d.注意,目标数组一定要大于字符串大小,即sizeof(d)>strlen©,否则会造成访问越界.

hello
hellolen=5
mystrlen len=5
helloworld
c?d 0
helloworld

strcmp函数用来比较两个字符串的大小,由于字符数组c中的字符串与d相等,所以这里的返回值为0,如果c中的字符串大于d,那么返回值为1;如果c中的字符串小于d,那么返回值为-1,如何比较两个字符串的大小呢?具体操作是从头开始,比较相同位置字符的ASCII码值,若发现不相等则直接返回,否则接着往后比较.例如,strcmp(“hello” ," how")的返回值是-1,即"“hello"小于"how”,因为第一个字符h相等,接着比较第二个位置的字符, e的ASCII码值小于o的,然后返回-1.

strcat函数用来将一个字符串接到另外一个字符串的末尾.例中字符数组c中存储的是
“hello”,我们将d中的"world"与c拼接,最终结果为"helloworld"。注意,目标数组必须大于拼接后的字符串大小,即sizeof©>strlen(“helloworld”).

这篇关于【C语言基础考研向】11 gets函数与puts函数及str系列字符串操作函数的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/631934

相关文章

Spring Security 从入门到进阶系列教程

Spring Security 入门系列 《保护 Web 应用的安全》 《Spring-Security-入门(一):登录与退出》 《Spring-Security-入门(二):基于数据库验证》 《Spring-Security-入门(三):密码加密》 《Spring-Security-入门(四):自定义-Filter》 《Spring-Security-入门(五):在 Sprin

hdu1171(母函数或多重背包)

题意:把物品分成两份,使得价值最接近 可以用背包,或者是母函数来解,母函数(1 + x^v+x^2v+.....+x^num*v)(1 + x^v+x^2v+.....+x^num*v)(1 + x^v+x^2v+.....+x^num*v) 其中指数为价值,每一项的数目为(该物品数+1)个 代码如下: #include<iostream>#include<algorithm>

零基础学习Redis(10) -- zset类型命令使用

zset是有序集合,内部除了存储元素外,还会存储一个score,存储在zset中的元素会按照score的大小升序排列,不同元素的score可以重复,score相同的元素会按照元素的字典序排列。 1. zset常用命令 1.1 zadd  zadd key [NX | XX] [GT | LT]   [CH] [INCR] score member [score member ...]

科研绘图系列:R语言扩展物种堆积图(Extended Stacked Barplot)

介绍 R语言的扩展物种堆积图是一种数据可视化工具,它不仅展示了物种的堆积结果,还整合了不同样本分组之间的差异性分析结果。这种图形表示方法能够直观地比较不同物种在各个分组中的显著性差异,为研究者提供了一种有效的数据解读方式。 加载R包 knitr::opts_chunk$set(warning = F, message = F)library(tidyverse)library(phyl

透彻!驯服大型语言模型(LLMs)的五种方法,及具体方法选择思路

引言 随着时间的发展,大型语言模型不再停留在演示阶段而是逐步面向生产系统的应用,随着人们期望的不断增加,目标也发生了巨大的变化。在短短的几个月的时间里,人们对大模型的认识已经从对其zero-shot能力感到惊讶,转变为考虑改进模型质量、提高模型可用性。 「大语言模型(LLMs)其实就是利用高容量的模型架构(例如Transformer)对海量的、多种多样的数据分布进行建模得到,它包含了大量的先验

【生成模型系列(初级)】嵌入(Embedding)方程——自然语言处理的数学灵魂【通俗理解】

【通俗理解】嵌入(Embedding)方程——自然语言处理的数学灵魂 关键词提炼 #嵌入方程 #自然语言处理 #词向量 #机器学习 #神经网络 #向量空间模型 #Siri #Google翻译 #AlexNet 第一节:嵌入方程的类比与核心概念【尽可能通俗】 嵌入方程可以被看作是自然语言处理中的“翻译机”,它将文本中的单词或短语转换成计算机能够理解的数学形式,即向量。 正如翻译机将一种语言

【Linux 从基础到进阶】Ansible自动化运维工具使用

Ansible自动化运维工具使用 Ansible 是一款开源的自动化运维工具,采用无代理架构(agentless),基于 SSH 连接进行管理,具有简单易用、灵活强大、可扩展性高等特点。它广泛用于服务器管理、应用部署、配置管理等任务。本文将介绍 Ansible 的安装、基本使用方法及一些实际运维场景中的应用,旨在帮助运维人员快速上手并熟练运用 Ansible。 1. Ansible的核心概念

AI基础 L9 Local Search II 局部搜索

Local Beam search 对于当前的所有k个状态,生成它们的所有可能后继状态。 检查生成的后继状态中是否有任何状态是解决方案。 如果所有后继状态都不是解决方案,则从所有后继状态中选择k个最佳状态。 当达到预设的迭代次数或满足某个终止条件时,算法停止。 — Choose k successors randomly, biased towards good ones — Close

flume系列之:查看flume系统日志、查看统计flume日志类型、查看flume日志

遍历指定目录下多个文件查找指定内容 服务器系统日志会记录flume相关日志 cat /var/log/messages |grep -i oom 查找系统日志中关于flume的指定日志 import osdef search_string_in_files(directory, search_string):count = 0

C++操作符重载实例(独立函数)

C++操作符重载实例,我们把坐标值CVector的加法进行重载,计算c3=c1+c2时,也就是计算x3=x1+x2,y3=y1+y2,今天我们以独立函数的方式重载操作符+(加号),以下是C++代码: c1802.cpp源代码: D:\YcjWork\CppTour>vim c1802.cpp #include <iostream>using namespace std;/*** 以独立函数