网站首页 > 技术文章 正文
学习工控知识,就来工控小新
农历十一月十九日 2023/12/ 31
往期推荐
2023年12月28日,每日花费一分钟练习C语言
2023年12月27日,每日花费一分钟练习C语言
每日一练
/ Daily Exercises
题目:
找出字符串中第一个只出现一次的字符 输入描述: 输入一个非空字符串 输出描述: 输出第一个只出现一次的字符,如果不存在输出-1
题目分析
题目要求我们找出字符串中第一个只出现一次的字符,如果不存在,就输出-1。输入是一个非空字符串,输出是一个字符或者-1。我们可以用一个数组来存储每个字符出现的次数,然后再遍历一遍字符串,找到第一个出现次数为1的字符,返回它。如果没有这样的字符,就返回-1。这种方法的时间复杂度是O(n),空间复杂度是O(1),其中 n 是字符串的长度。
程序展示
根据上述的分析,我们可以用以下的C语言程序来实现题目的要求。该程序在VC6.0的环境下运行正常,输入一个非空字符串,输出第一个只出现一次的字符,如果不存在输出-1。
#include <stdio.h>
#include <string.h>
// 定义一个常量,表示字符的种类数,这里假设只有ASCII码的256种字符
#define CHAR_NUM 256
// 定义一个函数,给定一个非空字符串,返回第一个只出现一次的字符,如果不存在,返回-1
char firstUniqChar(char* s)
{
int count[CHAR_NUM]; // 定义一个数组,用来存储每个字符出现的次数
memset(count, 0, sizeof(count)); // 初始化数组为0
int i;
for (i = 0; i < strlen(s); i++)
{ // 遍历字符串
count[s[i]]++; // 将对应的字符出现的次数加1
}
for (i = 0; i < strlen(s); i++)
{ // 再次遍历字符串
if (count[s[i]] == 1) // 如果找到第一个出现次数为1的字符
return s[i]; // 返回它
}
return -1; // 如果没有这样的字符,返回-1
}
// 主函数
int main()
{
char s[100]; // 定义一个字符串
printf("请输入一个非空字符串:\n"); // 提示输入
scanf("%s", s); // 读取输入
char res = firstUniqChar(s); // 调用函数,得到结果
if (res == -1) // 如果结果是-1
printf("不存在只出现一次的字符\n"); // 输出提示信息
else // 如果结果是一个字符
printf("第一个只出现一次的字符是%c\n", res); // 输出结果
return 0;
}
程序测试
为了验证我们的程序是否正确,我们可以用一些测试用例来检验。我们可以
输入一个非空字符串,经由程序判断哪个是只出现一次的字符
源代码获取
#软件下载通道# 我用夸克网盘分享了「20231231」,点击链接即可保存。打开「夸克APP」,无需下载在线播放视频,畅享原画5倍速,支持电视投屏。 链接:https://pan.quark.cn/s/8531bdd45369 (链接和提取码建议复制粘贴,手动输入容易出现错误) | |
#支持一下# 分享整理,测试发布不易 如果您方便的话可以帮忙点一下↓↓ 谢谢大家! |
下期题目
题目:
字符串相乘
给定两个以字符串形式表示的非负整数num1和num2返回num1和num2的乘积,它们的乘积也表示为字符串形式。
示例 1: 输入: num1 =“2",num2 =“3" 输出:"6"
示例 2: 输入: num1 =“123",num2 =“456"输出:“56088"
说明:
1.num1和num2的长度小于110。
2.num1和num2 只包含数字0-9。
3.num1和num2 均不以零开头,除非是数字0本身。
4不能使用任何标准库的大数类型 (比如Biglnteger)或直接将输入转换为整数来处理。
点赞加关注,学习不迷路
微信公众号|工控小新
学习工控知识就来工控小新,为你提供工控笔记知识:EPLAN电气绘图 | TIA博图基础 | CAD | C语言教学 | 单片机基础 | 三菱PLC ... 每日持续更新中
- 上一篇: 「C语言初级」.字符串基本操作之二
- 下一篇: C语言快速入门手册4.格式字符串(c语言常用格式字符)
猜你喜欢
- 2024-10-05 Python基础知识——字符串(python字符串的常用方法)
- 2024-10-05 你会在 Python 中使用字符串吗?(python字符串需要用什么包裹)
- 2024-10-05 javascript内置对象总结 - String
- 2024-10-05 Python 中字符串和字符串处理的综合指南
- 2024-10-05 C++中的string用法(c++ string用法总结)
- 2024-10-05 Excel文本函数——CONCATENATE函数详解
- 2024-10-05 探究C语言中字符串大小和长度易错点
- 2024-10-05 【PythonTip题库300题】第47题:字符串中缺失的字母
- 2024-10-05 Rust: 字符串总结,虽常见但非常重要
- 2024-10-05 这些字符串处理函数你用过吗(字符串常用操作函数)
- 08-03MySQL数据库的预处理详解
- 08-03《阿常·MySQL 70讲》全套教学视频
- 08-03隐式等待、显示等待和强制等待
- 08-03零基础C#上位机框架项目实例(完结篇)
- 08-03一文搞懂构建Web内容的技术
- 08-03西门子WINCC中的VBScript(VBS)常用于自动化脚本开发
- 08-03力控和sql2000之间的数据转储
- 08-03组态王|通过日历控件选择时间段查询历史报警
- 1521℃桌面软件开发新体验!用 Blazor Hybrid 打造简洁高效的视频处理工具
- 627℃Dify工具使用全场景:dify-sandbox沙盒的原理(源码篇·第2期)
- 527℃MySQL service启动脚本浅析(r12笔记第59天)
- 492℃服务器异常重启,导致mysql启动失败,问题解决过程记录
- 492℃启用MySQL查询缓存(mysql8.0查询缓存)
- 479℃「赵强老师」MySQL的闪回(赵强iso是哪个大学毕业的)
- 461℃mysql服务怎么启动和关闭?(mysql服务怎么启动和关闭)
- 458℃MySQL server PID file could not be found!失败
- 最近发表
- 标签列表
-
- cmd/c (90)
- c++中::是什么意思 (84)
- 标签用于 (71)
- 主键只能有一个吗 (77)
- c#console.writeline不显示 (95)
- pythoncase语句 (88)
- es6includes (74)
- sqlset (76)
- windowsscripthost (69)
- apt-getinstall-y (100)
- node_modules怎么生成 (87)
- chromepost (71)
- flexdirection (73)
- c++int转char (80)
- htmlbackground-image (68)
- static函数和普通函数 (76)
- el-date-picker开始日期早于结束日期 (70)
- asynccallback (71)
- localstorage.removeitem (74)
- vector线程安全吗 (70)
- java (73)
- js数组插入 (83)
- mac安装java (72)
- 查看mysql是否启动 (70)
- 无效的列索引 (74)