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

C语言中字符数组与字符串的输入输出方法对比及应用技巧

c语言没有字符串(string)这种类型,但是可以用字符数组代替输入方法如果知道字符数组的长度,我们可以用下面的方法输入chars[10];长度为10的

c语言没有字符串(string)这种类型,但是可以用字符数组代替

输入方法

如果知道字符数组的长度,我们可以用下面的方法输入

char s[10];//长度为10的字符数组

for(int i&#61;0;i<5;i&#43;&#43;)//输入五个字符

scanf("%c",&s[i]);

在不知道长度的情况下&#xff0c;可以用下面的方法输入

char s[100];//定义一个足够长的字符数组

scanf("%s",s);//方法一&#xff0c;注意不需要用&&#xff0c;因为数组名s就是数组的首地址

gets(s);//方法二

方法一和二都可以接收一串字符&#xff0c;区别是&#xff0c;方法一遇到空格和回车就会停止&#xff0c;方法二遇到回车才会停止

举个例子&#xff0c;如果你输入abc abc然后回车&#xff0c;输出的时候&#xff0c;方法一只会输出abc&#xff0c;而方法二可以输出完整的abc abc

输出方法

如果知道长度&#xff0c;可以用for循环直接printf输出每个字符

如果不知道&#xff0c;可以用下面的方法

char s[100];

gets(s);//输入

printf("%s",s)&#xff1b;//输出方法一

puts(s);//输出方法二

要注意的是&#xff0c;如果你是用for循环来输入字符的&#xff0c;那么不可以用puts或者%s来输出&#xff0c;否则会出现乱码。(比如vc的烫烫烫)

char s[10];//长度为10的字符数组

for(int i&#61;0;i<5;i&#43;&#43;)//输入五个字符

scanf("%c",&s[i]);

puts(s);//输出乱码

printf("%s",s);//输出乱码

这是因为&#xff0c;如果你输入用的是gets()或者scanf("%s",s),他会自动在字符的最后加上一个&#39;\0&#39;&#xff0c;用puts或者%s输出的时候&#xff0c;他会找到字符中的&#39;\0&#39;&#xff0c;然后把&#39;\0&#39;前的字符全部输出&#xff0c;而用for则不会给你加&#39;\0&#39;

如果我们把代码改成下面这样

char s[10];//长度为10的字符数组

for(int i&#61;0;i<5;i&#43;&#43;)//输入五个字符

scanf("%c",&s[i]);

s[i]&#61;&#39;\0&#39;;//给最后加上\0

puts(s);//输出正常

printf("%s",s);//输出正常



推荐阅读
  • Ihaveastringwithquotesaroundthepathasfollows:我在路径周围有一个带引号的字符串,如下所示:C:\ProgramFiles(x ... [详细]
  • JavaScript 基础语法指南
    本文详细介绍了 JavaScript 的基础语法,包括变量、数据类型、运算符、语句和函数等内容,旨在为初学者提供全面的入门指导。 ... [详细]
  • JSOI2010 蔬菜庆典:树结构中的无限大权值问题
    本文探讨了 JSOI2010 的蔬菜庆典问题,主要关注如何处理非根非叶子节点的无限大权值情况。通过分析根节点及其子树的特性,提出了有效的解决方案,并详细解释了算法的实现过程。 ... [详细]
  • 深入解析Java枚举及其高级特性
    本文详细介绍了Java枚举的概念、语法、使用规则和应用场景,并探讨了其在实际编程中的高级应用。所有相关内容已收录于GitHub仓库[JavaLearningmanual](https://github.com/Ziphtracks/JavaLearningmanual),欢迎Star并持续关注。 ... [详细]
  • 本题来自WC2014,题目编号为BZOJ3435、洛谷P3920和UOJ55。该问题描述了一棵不断生长的带权树及其节点上小精灵之间的友谊关系,要求实时计算每次新增节点后树上所有可能的朋友对数。 ... [详细]
  • 在高并发需求的C++项目中,我们最初选择了JsonCpp进行JSON解析和序列化。然而,在处理大数据量时,JsonCpp频繁抛出异常,尤其是在多线程环境下问题更为突出。通过分析发现,旧版本的JsonCpp存在多线程安全性和性能瓶颈。经过评估,我们最终选择了RapidJSON作为替代方案,并实现了显著的性能提升。 ... [详细]
  • 本文详细解释了为什么在成功执行移动赋值操作后,对象的析构函数会被调用,并提供了代码示例和详细的分析。 ... [详细]
  • 本文探讨了如何使用自增和自减运算符遍历二维数组中的元素。通过实例详细解释了指针与二维数组结合使用的正确方法,并解答了常见的错误用法。 ... [详细]
  • 深入解析for与foreach遍历集合时的性能差异
    本文将详细探讨for循环和foreach(迭代器)在遍历集合时的性能差异,并通过实际代码示例和源码分析,帮助读者理解这两种遍历方式的不同之处。文章内容丰富且专业,旨在为编程爱好者提供有价值的参考。 ... [详细]
  • 利用决策树预测NBA比赛胜负的Python数据挖掘实践
    本文通过使用2013-14赛季NBA赛程与结果数据集以及2013年NBA排名数据,结合《Python数据挖掘入门与实践》一书中的方法,展示如何应用决策树算法进行比赛胜负预测。我们将详细讲解数据预处理、特征工程及模型评估等关键步骤。 ... [详细]
  • 丽江客栈选择问题
    本文介绍了一道经典的算法题,题目涉及在丽江河边的n家特色客栈中选择住宿方案。两位游客希望住在色调相同的两家客栈,并在晚上选择一家最低消费不超过p元的咖啡店小聚。我们将详细探讨如何计算满足条件的住宿方案总数。 ... [详细]
  • 本文探讨了在Java中如何正确地将多个不同的数组插入到ArrayList中,避免所有数组在插入后变得相同的问题。我们将分析代码中的问题,并提供解决方案。 ... [详细]
  • 深入解析Java虚拟机(JVM)架构与原理
    本文旨在为读者提供对Java虚拟机(JVM)的全面理解,涵盖其主要组成部分、工作原理及其在不同平台上的实现。通过详细探讨JVM的结构和内部机制,帮助开发者更好地掌握Java编程的核心技术。 ... [详细]
  • 深入解析动态代理模式:23种设计模式之三
    在设计模式中,动态代理模式是应用最为广泛的一种代理模式。它允许我们在运行时动态创建代理对象,并在调用方法时进行增强处理。本文将详细介绍动态代理的实现机制及其应用场景。 ... [详细]
  • 深入解析ArrayList与LinkedList的差异
    本文详细对比了Java中ArrayList和LinkedList两种常用集合类的特性、性能及适用场景,通过代码示例进行测试,并结合实际应用场景分析其优缺点。 ... [详细]
author-avatar
seazz2001
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有