C语言—字符数组(3)

可能不是那么的完整,先凑合看吧,如果我学会如何修改以后,我慢慢回来修改的

1.编写程序实现对两个字符串的连接功能;

法一:不使用strcat函数,写程序直接实现,记得添加结束符,不然程序访问数组时候将变得不可预测

/*1.编写程序实现对两个字符串的连接功能*/#include <stdio.h>int main(void)
{char str1[] = "hello,";char str2[] = "world!";char str[100] = {0};  //用于存储连接后的字符串printf("字符串1: %2s 字符串2: %2s\n",str1,str2);int index1 = 0; //初始化下标while(str1[index1] != '\0')  //复制str1到str{str[index1] = str1[index1];index1++;}int index2 = 0;while(str2[index2] != '\0')  //复制str2到str{str[index1] = str2[index2];index1++;index2++;}str[index1] = '\0';  //在连接后的字符串末尾添加字符串结束符printf("连接后的字符串: %s\n",str);return 0;
}

法二:使用strcat函数

/*1.编写程序实现对两个字符串的连接功能,使用strcat函数*/#include <stdio.h>
#include <string.h>int main(void)
{char str[32] = {0};  //存储连接后的字符串char str1[] = "hello,";char str2[] = "world!";printf("连接之前字符串1: %2s 字符串2: %2s\n",str1,str2);strcat(str,str1);  //strcat函数连接字符串1和字符串2strcat(str,str2);printf("连接后的字符串是: %s\n",str);return 0;}


2.编写程序实现对字符串有效数据长度的计算;

法一:不用strlen函数

*2.编写程序实现对字符串有效数据长度的计算;*/#include <stdio.h>int main(void)
{char str[8];unsigned int len = 0;printf("请输入一个字符串:");fgets(str,sizeof(str),stdin);while(str[len] != '\0')  //遇到结束符停止循环{len++;  //若未遇到结束符则增加有效数据长度}//屏蔽这里为还不是很懂,fgets()函数会自动添加结束符,我想添加判断语句却不行`/*if(len > 7){printf("输入字符串太长,请重新输入。\n");}*/printf("字符串中有效数据长度为: %u\n",len - 1); //减去结束符就是长度return 0;
}

法二:strlen函数

/*strlen函数*/#include <stdio.h>
#include <string.h>int main(void)
{char str[8];unsigned int len;printf("请输入一个字符串:");fgets(str,sizeof(str),stdin);len = strlen(str) - 1;printf("输入的有效的字符串长度是: %u\n",len);return 0;}


3.编程实现随机输出多个字符串中的某个;

/*3.编程实现随机输出多个字符串中的某个;*/#include <stdio.h>
#include <time.h>
#include <string.h>
#include <stdlib.h>#define r 3
#define l 32int main(void)
{char arr[r][l] = {"hello","Spring Festival","Happy New Year"};srand(time(NULL)); //生成种子数int randow;randow = rand() % r;  //随机生成选中的字符串的数字放入randow变量中printf("随机选中的字符串是: %s\n",arr[randow]);return 0;
}


思考题: 
    计算字符串中所有数字的和
    字符串“123abd23ee1”==>123 + 23 + 1 = 147

for循环和while循环,思想是一致的,for相对要完整一些,while只是针对这一串数字,我记得老师也有讲这个题,但是我找不到了,等我找到我再放上来

#include <stdio.h>
#include <string.h>int main(void)
{char str[] = "123and23ee1";printf("字符串为: %s\n", str);int num = 0; // 初始化一个变量来存储连续数字的值int sum = 0; // 初始化一个变量来存储所有数字的和int found = 0; // 初始化一个变量来标记是否找到数字for (int i = 0; str[i] != '\0'; i++) // 循环遍历字符串中的每个字符{if (str[i] >= '0' && str[i] <= '9') // 如果字符是数字{num = num * 10 + (str[i] - '0'); // 将数字字符转换为数字并累加到numfound = 1; // 设置found为1,表示找到了数字}else // 如果字符不是数字{if (found) // 如果之前找到了数字{sum += num; // 将num加到sum中}num = 0; // 将num重置为0found = 0; // 将found重置为0}}if (num) // 如果num不为0,说明最后还有一个数字{sum += num; // 将其加到sum中}printf("字符串中数字总和为: %d\n", sum); // 打印字符串中数字的总和return 0; // 返回0,表示程序正常退出
}
#include <stdio.h>
#include <string.h> int main(void)
{char str[] = "123abd23ee1"; // 定义一个字符数组,并初始化为给定的字符串printf("字符串为: %s\n",str); // 打印输入的字符串int sum = 0; // 定义一个变量来存储数字的和int num = 0; // 定义一个变量来存储当前数字的值int i = 0; // 定义一个索引变量,用于遍历字符串while(str[i] != '\0') // 当字符串结束符之前,循环继续{if(str[i] >= '0' && str[i] <= '9') // 如果字符是数字{num = num * 10 + (str[i] - '0'); // 将当前数字乘以10,然后加上字符转换为的数字}else // 如果字符不是数字{sum += num; // 将当前数字的和加到总和中num = 0; // 将当前数字重置为0}i++; // 索引变量增加1,指向下一个字符}sum += num; // 将最后一个数字加到总和中printf("字符串中所有数字的和为: %d\n",sum); // 打印字符串中所有数字的和return 0; // 返回0,表示程序正常退出
}

这个写完就进入函数啦,嘿嘿

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

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

相关文章

【教程】C++语言基础学习笔记(八)——函数

写在前面&#xff1a; 如果文章对你有帮助&#xff0c;记得点赞关注加收藏一波&#xff0c;利于以后需要的时候复习&#xff0c;多谢支持&#xff01; 【C语言基础学习】系列文章 第一章 《项目与程序结构》 第二章 《数据类型》 第三章 《运算符》 第四章 《流程控制》 第五章…

耳机壳UV树脂制作私模定制耳塞需要哪些工具和材料呢?

制作私模定制耳塞需要使用到一些工具和材料&#xff0c;包括但不限于以下内容&#xff1a; UV树脂&#xff1a;用于制作耳塞的主体部分&#xff0c;具有高硬度、耐磨、耐高温、环保等优点。耳模材料&#xff1a;用于获取用户的耳型&#xff0c;通常是一些快速固化的材料&#…

LeetCode 0987.二叉树的垂序遍历:遍历时存节点信息,遍历完自定义排序

【LetMeFly】987.二叉树的垂序遍历&#xff1a;遍历时存节点信息&#xff0c;遍历完自定义排序 力扣题目链接&#xff1a;https://leetcode.cn/problems/vertical-order-traversal-of-a-binary-tree/ 给你二叉树的根结点 root &#xff0c;请你设计算法计算二叉树的 垂序遍历…

【C语言】【力扣】7.整数反转和9.回文数

一、整数反转 1.1 个人思考过程 初解&#xff1a;出现ERROR&#xff0c;数据溢出的情况下应该返回0。&#xff08;错误&#xff09; int reverse(int x){int y0;while(x!0){yy*10x%10;x/10; }return y; } 再解&#xff1a;加上数据溢出判断条件。&#xff08;正确&#…

“bound drug/molecule”or “unbound drug/molecule”、molecule shape、sketching是什么?

“bound drug/molecule”or “unbound drug/molecule” For clarity, the following terms will be used throughout this study: “bound drug/molecule” (or “unbound drug/molecule”) refers to the drug/molecule that is bound (or unbound) to proteins [48]. 意思就是…

Java实现快乐贩卖馆管理系统 JAVA+Vue+SpringBoot+MySQL

目录 一、摘要1.1 项目介绍1.2 项目录屏 二、功能模块2.1 数据中心模块2.2 搞笑视频模块2.3 视频收藏模块2.4 视频评分模块2.5 视频交易模块2.6 视频好友模块 三、系统设计3.1 用例设计3.2 数据库设计3.2.1 搞笑视频表3.2.2 视频收藏表3.2.3 视频评分表3.2.4 视频交易表 四、系…

【前沿技术杂谈:AI 模型训练成本】到 2030 年,AI 模型训练成本预计将从 1 亿美元增加到 5 亿美元

【前沿技术杂谈&#xff1a;AI 模型训练成本】到 2030 年&#xff0c;AI 模型训练成本预计将从 1 亿美元增加到 5 亿美元 简述五年后&#xff0c;人工智能将掌握在谁的手中&#xff1f; 简述 根据 OpenAI 最近的一份报告&#xff0c;到 2030 年&#xff0c;训练大型 AI 模型的成…

npm报错之package-lock.json found. 问题和淘宝镜像源过期问题

1、package-lock.json found. 问题的解决 在执行yarn add react-transition-group -S 安装react-transition-group时出现package-lock.json found. Your project contains lock files generated by tools other than Yarn. It is advised not to mix package managers in orde…

Mybatis Day02

增删改查 环境准备 创建一个emp表创建一个新的springboot工程&#xff0c;选择mysql、lombok、mybatis依赖application.properties中引入数据库连接信息创建对应的实体类Emp准备Mapper接口EmpMapper&#xff0c;mapper代表程序运行时自动创建接口的代理对象&#xff0c;并放入…

EasyCaptcha,开源图形验证码新标杆!

引言&#xff1a; 随着互联网的普及&#xff0c;验证码已成为网站和应用程序中不可或缺的安全组件。它能够有效地防止自动化攻击、垃圾邮件和机器人活动。在众多验证码解决方案中&#xff0c;Easy-captcha以其简单易用和高度可定制的特点受到了开发者的青睐。本文将指导读者如…

Java 学习和实践笔记(8)

视频解释说&#xff0c;上图不用我们常规的写法&#xff0c;仅仅只是为了在同样的情况下&#xff0c;少写一个a而已&#xff01;这我目前不能理解。毕竟后面这种对初学者来说&#xff0c;看起来更一目了解。

爬爬爬——今天是浏览器窗口切换和给所选人打钩(自动化)

学习爬虫路还很长&#xff0c;第一阶段花了好多天了&#xff0c;还在底层&#xff0c;虽然不是我专业要学习的语言&#xff0c;和必备的知识&#xff0c;但是我感觉还挺有意思的。加油&#xff0c;这两天把建模和ai也不学了&#xff0c;唉过年了懒了&#xff01; 加油坚持就是…

LeetCode、1318. 或运算的最小翻转次数【中等,位运算】

文章目录 前言LeetCode、1318. 或运算的最小翻转次数【中等&#xff0c;位运算】题目链接与分类题解位运算 资料获取 前言 博主介绍&#xff1a;✌目前全网粉丝2W&#xff0c;csdn博客专家、Java领域优质创作者&#xff0c;博客之星、阿里云平台优质作者、专注于Java后端技术领…

Linux:信号的处理

文章目录 信号处理 本篇总结的是关于信号的处理 信号处理 在之前有这样的观点&#xff1a;信号在合适的时候被处理好&#xff0c;当进程收到信号后&#xff0c;当前进程可能在做优先级更高的事&#xff0c;所以它来不及处理这个信号&#xff0c;那么就会把这个信号暂时保存起…

从零开始:Linux下的Miniconda安装教程

&#x1f680;从零开始&#xff1a;Linux下的Miniconda安装教程&#x1f680; &#x1f335;文章目录&#x1f335; &#x1f333;引言&#x1f333;&#x1f333;二、Miniconda简介&#xff1a;开启您的数据科学之旅的得力助手&#xff01; &#x1f333;&#x1f333;三、Lin…

Linux_文件系统

假定外部存储设备为磁盘&#xff0c;文件如果没有被使用&#xff0c;那么它静静躺在磁盘上&#xff0c;如果它被使用&#xff0c;则文件将被加载进内存中。故此&#xff0c;可以将文件分为内存文件和磁盘文件。 内存文件 磁盘文件 软、硬链接 一.内存文件 1.1 c语言的文件接口 …

OpenMVG(EXIF、畸变、仿射特征、特征匹配)

本人之前也研究过OpenMVS但是对于OpenMVG只是原理层次的了解&#xff0c;因此乘着过年期间对这个库进行详细的学习。 目录 1 OpenMVG编译与简单测试 1.1 sfm_data.json获取 1.2 计算特征 2 OpenMVG整个流程的运行测试 3 OpenMVG实战 3.1 SVG绘制 3.2 解析图片的EXIF信息…

Decian 12.x基于LNMP安装phpIPAM(IP管理系统)

phpipam是一个开源Web IP地址管理应用程序&#xff08;IPAM&#xff09;。其目标是提供轻便&#xff0c;且有用的IP地址管理系统。它是基于PHP的应用程序&#xff0c;具有MySQL数据库后端&#xff0c;使用jQuery库&#xff0c;ajax和HTML5 / CSS3功能。 在Debian 12中&…

MogaNet实战:使用 MogaNet实现图像分类任务(二)

文章目录 训练部分导入项目使用的库设置随机因子设置全局参数图像预处理与增强读取数据设置Loss设置模型设置优化器和学习率调整策略设置混合精度&#xff0c;DP多卡&#xff0c;EMA定义训练和验证函数训练函数验证函数调用训练和验证方法 运行以及结果查看测试完整的代码 在上…

小游戏和GUI编程(7) | SimpleNN 界面源码解析

小游戏和GUI编程(7) | SimpleNN 界面源码解析 0. 简介 SimpleNN 是 AdamYuan 在高中一年级时用 1 天时间写出来的简易 CNN, 使用 SFML 做 UI, 用于交互式输入手写数字&#xff0c;这个数字被训练好的 CNN 网络执行推理得到识别结果, 它的运行效果如下&#xff1a; 这一篇我们…