【C语言】字符串 和 ctype.h 中的函数 练习

news2025/6/8 6:13:03
前面总结了有关字符串和ctype.h的文章,接下来就以几个例子来练习一下,以巩固之前的基础概念。
  • 注意:以下示例都有更简单更高效的解决方法,但本次仅以巩固基础为目的,所以方法可能稍作繁琐
  1. Leetcode 344.反转字符串

编写一个函数,其作用是将输入的字符串反转过来。输入字符串以字符数组 s 的形式给出。不要给另外的数组分配额外的空间,你必须原地修改输入数组、使用 O(1) 的额外空间解决这一问题。

  • 示例 1:
    输入:s = [“h”,“e”,“l”,“l”,“o”]
    输出:[“o”,“l”,“l”,“e”,“h”]

  • 示例 2:
    输入:s = [“H”,“a”,“n”,“n”,“a”,“h”]
    输出:[“h”,“a”,“n”,“n”,“a”,“H”]

提示:

  • 1 <= s.length <= 105
  • s[i] 都是 ASCII 码表中的可打印字符
/*
	将首尾数据互换,直至逼近中间的一个或两个数据,这样即可完成反转字符串	
*/
#include <stdio.h>
#include <string.h> // for strlen

// 利用传址的方式实现数据互换(不可以用传值方式)
void swap(char *a, char *b){
	char c = *a;
    *a = *b;
	*b = c;
}

void reverseString(char* s, int sSize) {
	for (int i = 0; i < sSize / 2; i++){
	       swap(s + i, s + sSize - i - 1);
	}
}

int main(){
	char s[] = "This is a Test";
	printf("Primary string: %s\n", s);
	int size = strlen(s);
		
	reverseString(s, size);
	printf("Reverse string: %s\n", s);
		
	return 0;
}
  • 输出结果
    输出结果

2. Leetcode 125. 验证回文串

如果在将所有大写字符转换为小写字符、并移除所有非字母数字字符之后,短语正着读和反着读都一样。则可以认为该短语是一个 回文串字母和数字都属于字母数字字符。 给你一个字符串 s,如果它是 回文串 ,返回 true ;否则,返回 false 。

  • 示例 1:
    输入: s = “A man, a plan, a canal: Panama”
    输出:true
    解释:“amanaplanacanalpanama” 是回文串。

  • 示例 2:
    输入:s = “race a car”
    输出:false
    解释:“raceacar” 不是回文串。

  • 示例 3:
    输入:s = " "
    输出:true
    解释:在移除非字母数字字符之后,s 是一个空字符串 “” 。
    由于空字符串正着反着读都一样,所以是回文串。

提示:

  • 1 <= s.length <= 2 * 105
  • s 仅由可打印的 ASCII 字符组成
/*
	1. 首先通过函数filter_ch将含有标点符号、空白字符的字符串
			转为一个只含有小写字母和数字的字符串
	2. 首尾字符一样的,直至逼近中间的一个和两个全部一样,那么就是回文的 
*/


#include <stdio.h>
#include <ctype.h> // 之前总结的
#include <stdbool.h> // 以后开一个新章节介绍
#include <string.h> // for strlen 计算字符串长度

// 利用传址方式,将源字符串中的所有字母转为小写字母
void filter_ch(char *s) {
    int i = 0, j = 0;
    while(s[i]) {
        if(isalnum(s[i])) { // 等价 isalpha(s[i]) || isdigit(s[i])
            s[j] = tolower(s[i]);
            j++;
        }
        i++;
    }
    s[j] = '\0';
}

bool isPalindrome(char* s) {
    filter_ch(s);
    int size = strlen(s); // 计算的是纯小写字母的长度
    for (int i = 0; i < size / 2; i++) {
        if (*(s + i) != *(s + size - i - 1)) {
            return false;
        }
    }
    return true;
}

int main() {
    char s[100] = "A man, a plan, a canal: Panama";

    if (isPalindrome(s)) {
        printf("The string is a palindrome.\n");
    } else {
        printf("The string is not a palindrome.\n");
    }

    return 0;
}

3. Leetcode 709. 转换成小写字符

给你一个字符串 s ,将该字符串中的大写字母转换成相同的小写字母, 返回新的字符串。

  • 示例 1:
    输入:s = “Hello”
    输出:“hello”

  • 示例 2:
    输入:s = “here”
    输出:“here”

  • 示例 3:
    输入:s = “LOVELY”
    输出:“lovely”

提示:

  • 1 <= s.length <= 100
  • s 由 ASCII 字符集中的可打印字符组成
/*
	直接用tolower函数就行了   哈哈哈开句玩笑
	下面有具体的实现方法
*/


#include <stdio.h>
#include <string.h> // for strlen 计算字符串长度

// tolower 函数的实现方法
int my_tolower(int c) {
    if (c >= 'A' && c <= 'Z') {
        c += 'a' - 'A'; // 字符型是以ASCII码的形式存储的
    }
    
    return c;
}

char* toLowerCase(char* s) {
    int size = strlen(s);
    for (int i = 0; i < size; i++){
        s[i] = my_tolower(s[i]);
    }
    return s;
}

int main() {
    char str[] = "Hello World";
    printf("Primary string: %s\n", str);
    
    toLowerCase(str);
    printf("New string: %s\n", str);
    return 0;
}
  • ASCII码的简单介绍
    ASCII码的简单介绍
    图中0的ASCII码记录十进制为48,A的十进制为65,a的十进制97
    在C语言中有,
    • 字符型 ‘9’ - ‘0’ 等价为 整型 9
    • ‘B’ + (‘a’ - ‘A’) 等价为 ‘B’ + ‘32’ 等价为 ‘b’

4. Leetcode 520.检测大写字母

我们定义,在以下情况时,单词的大写用法是正确的:

  • 全部字母都是大写,比如 “USA” 。
  • 单词中所有字母都不是大写,比如 “leetcode” 。
  • 如果单词不只含有一个字母,只有首字母大写, 比如 “Google” 。

给你一个字符串 word 。如果大写用法正确,返回 true ;否则,返回 false 。

  • 示例 1:
    输入:word = “USA”
    输出:true

  • 示例 2:
    输入:word = “FlaG”
    输出:false

提示:

  • 1 <= word.length <= 100
  • word 由小写和大写英文字母组成
#include <stdio.h>
#include <stdbool.h>
#include <ctype.h>

bool detectCapitalUse(char* word) {
    // 情况1:全部字母都是大写
    bool allUppercase = true;
    for (int i = 0; word[i] != '\0'; i++) {
        if (!isupper(word[i])) {
            allUppercase = false;
            break;
        }
    }
    if (allUppercase) {
        return true;
    }
    
    // 情况2:单词中所有字母都不是大写
    bool allLowercase = true;
    for (int i = 0; word[i] != '\0'; i++) {
        if (isupper(word[i])) {
            allLowercase = false;
            break;
        }
    }
    if (allLowercase) {
        return true;
    }
    
    // 情况3:只有首字母大写
    if (isupper(word[0]) && islower(word[1])) {
        bool remainingLowercase = true;
        for (int i = 2; word[i] != '\0'; i++) {
            if (isupper(word[i])) {
                remainingLowercase = false;
                break;
            }
        }
        if (remainingLowercase) {
            return true;
        }
    }
    
    return false;
}

int main() {
    const char *word1 = "USA";
    const char *word2 = "leetcode";
    const char *word3 = "Google";

    printf("%s\n", detectCapitalUse(word1) ? "true" : "false");  // 输出: true
    printf("%s\n", detectCapitalUse(word2) ? "true" : "false");  // 输出: true
    printf("%s\n", detectCapitalUse(word3) ? "true" : "false");  // 输出: true
    
    return 0;
}

如果对算法和刷题有兴趣的话,我在此推荐几个高质量的网站。

  1. 刷题网站
  • Leetcode
  • 洛谷
  • codeforces
  1. 算法学习
  • labuladong算法笔记
  • hello-algorithm

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

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

相关文章

HUAWEI WATCH 系列 eSIM 全新开通指南来了

HUAWEI WATCH 系列手表提供了eSIM硬件能力&#xff0c;致力为用户提供更便捷、高效的通信体验。但eSIM 业务是由运营商管理并提供服务的&#xff0c;当前运营商eSIM业务集中全面恢复&#xff0c;电信已经全面恢复&#xff0c;移动大部分省份已经全面放开和多号App开通方式&…

自由DIY预约小程序源码系统:适用于任何行业+自由DIY你的界面布局+全新升级的UI+多用户系统 带安装部署教程

随着移动互联网的普及&#xff0c;预约服务逐渐成为人们日常生活的一部分。从家政服务、医疗挂号到汽车保养&#xff0c;预约已经渗透到各个行业。然而&#xff0c;市面上的预约小程序大多功能单一&#xff0c;界面老旧&#xff0c;无法满足商家和用户的个性化需求。今天来给大…

PPT如何画半圆和半圆弧

一、画半圆 这里总结为两种方法&#xff0c;具体如下&#xff1a; 1.形状剪除法 1.打开PPT&#xff0c;选择“插入”->“形状”&#xff0c;接着画一个正圆 2.在刚才画好的圆形一半的位置&#xff0c;画出一个矩形 3.按住Ctrl键&#xff0c;同时选中圆形和矩形两个图形…

Pytest fixture 及 conftest详解!

前言 fixture是在测试函数运行前后&#xff0c;由pytest执行的外壳函数。fixture中的代码可以定制&#xff0c;满足多变的测试需求&#xff0c;包括定义传入测试中的数据集、配置测试前系统的初始状态、为批量测试提供数据源等等。fixture是pytest的精髓所在&#xff0c;类似u…

[排序算法] 如何解决快速排序特殊情况效率低的问题------三路划分

前言 在[C/C]排序算法 快速排序 (递归与非递归)一文中,对于快速排序的单趟排序一共讲了三种方法: hoare、挖坑法、双指针法 ,这三种方法实现的快速排序虽然在一般情况下效率很高,但是如果待排序数据存在大量重复数据,那这几种方法的效率就很低,而为了解决快速排序在这样特殊情况…

面试题:你如何理解 System.out.println()?

文章目录 前言首先分析System源码&#xff1a;out源码分析println分析 前言 如果你能自己读懂System.out.println()&#xff0c;就真正了解了Java面向对象编程的含义。 面向对象编程即创建了对象&#xff0c;所有的事情让对象帮亲力亲为&#xff08;即对象调用方法&#xff09…

CDD文件的制作

CDD文件 1、核查诊断调查表2、制作CDD3、Diva测试 1、核查诊断调查表 ECU级别&#xff1a;包括文档相关、控制器的诊断ID和时间参数&#xff0c;支持的服务&#xff0c;DTC、DID、刷写流程。 2、制作CDD 2.1、cddt编辑思路&#xff08;每一步都要根据调查表进行操作&#xf…

AI:112-基于卷积神经网络的美食图片识别与菜谱推荐

🚀点击这里跳转到本专栏,可查阅专栏顶置最新的指南宝典~ 🎉🎊🎉 你的技术旅程将在这里启航! 从基础到实践,深入学习。无论你是初学者还是经验丰富的老手,对于本专栏案例和项目实践都有参考学习意义。 ✨✨✨ 每一个案例都附带有在本地跑过的关键代码,详细讲解供…

基于Java SSM框架实现四六级在线考试系统项目【项目源码+论文说明】

基于java的SSM框架实现四六级在线考试系统演示 摘要 随着现在网络的快速发展&#xff0c;网上管理系统也逐渐快速发展起来&#xff0c;网上管理模式很快融入到了许多学院的之中&#xff0c;随之就产生了“四六级在线考试系统”&#xff0c;这样就让四六级在线考试系统更加方便…

修改选择框el-select样式,显示及下拉样式

修改选择框el-select样式,显示及下拉样式 .el-input__inner {background: rgba(25, 126, 195, 0.2);border: none;color: #fff; }.el-select-dropdown {background: rgba(19, 73, 104, 0.79);border: 2px solid #48e3ff;border-radius: 0; }.el-popper .popper__arrow {display…

随机森林,Random Forests Classifiers/Regressor

目录 介绍&#xff1a; 一、 Random Forests Classifiers&#xff08;离散型&#xff09; 1.1 数据处理 1.2建模 1.3特征值权值分析 1.4 特征值的缩减 二、Random Forests Regressor&#xff08;连续型&#xff09; 2.1数据处理 2.2建模 2.3调参 介绍&#xff1a; …

灵芝,到2025年有望达到9.2亿美元

灵芝是一种传统的药食两用菌&#xff0c;其具有丰富的营养成分和医疗价值&#xff0c;因此备受关注。全球市场分析 从全球市场来看&#xff0c;近年来灵芝的市场需求持续增长。据估计&#xff0c;2019年全球灵芝市场规模为4.1亿美元&#xff0c;到2025年有望达到9.2亿美元。市场…

山西电力市场日前价格预测【2024-01-05】

日前价格预测 预测说明&#xff1a; 如上图所示&#xff0c;预测明日&#xff08;2024-01-05&#xff09;山西电力市场全天平均日前电价为259.10元/MWh。其中&#xff0c;最高日前电价为363.99元/MWh&#xff0c;预计出现在18:00。最低日前电价为0.00元/MWh&#xff0c;预计出…

跨模态检索论文阅读:Plug-and-Play Regulators for Image-Text Matching用于图像文本匹配的即插即用调节器

Plug-and-Play Regulators for Image-Text Matching用于图像文本匹配的即插即用调节器 利用细粒度的对应关系和视觉语义比对在图像-文本匹配中显示出巨大的潜力。通常&#xff0c;最近的方法首先使用跨模态注意力单元来捕捉潜在的区域-单词交互&#xff0c;然后整合所有比对以获…

如何使用VsCode编译C语言?

下载VsCode (1) 解压到D盘跟目录 (2) 运行[vscode.reg]&#xff0c;注册右键菜单 (3) 进入[pack]文件夹&#xff0c;运行[install.bat]。安装基本插件。 下载mingw32 (1) 解压任意目录 (2) 我的电脑右键–高级系统设置–高级–环境变量–系统变量–Path(双击)–空白行(双击)–…

Arduino使用PWM驱动TB6612控制直流减速电机

目录 一、PWM介绍 二、硬件介绍 1、设备型号 2、接线图 3、TB6612控制电机转动逻辑 &#xff08;1&#xff09;控制逻辑 &#xff08;2&#xff09;真值表 4、G37系列JGB-520直流减速电机 三、测试程序 1、电机正反转控制 2、编码器脉冲读取 &#xff08;1&#xf…

柯桥小语种学习,留学韩语 生活日常口语 语法

① N이다/A/V/았ㄹ/을지도 모르다 说不定 이미 도착했을 지도 모르니까 전화해 봐요 说不定已经到了&#xff0c;打电话试试 주말에 세일이 있을지도 모르니까 주말에 가 보자 周末说不定会搞活动&#xff0c;我们周末去吧 ② ㄴ/은/는/았었는/ㄹ/을지 모르다 不知道 처음이…

《Aspect Sentiment Quad Prediction as Paraphrase Generation》论文阅读

文章目录 文章介绍文章模型问题定义文章模型PARAPHRASE建模 文章地址&#xff1a; https://arxiv.org/abs/2110.00796 文章介绍 这篇文章在已有的方面级情感分析任务的基础了研究了一项新的任务&#xff1a;方面级情感四元组提取&#xff08;Aspect Sentiment Quad Prediction…

【UEFI基础】EDK网络框架(基础说明)

基础说明 UEFI中的网络框架大致如下&#xff1a; 红框部分是实现UEFI的EDK2开源项目中网络框架自带的实现&#xff0c;红框之外的部分需要网卡设备商提供驱动。UEFI下通常推荐使用最右边的形式&#xff0c;即网卡设备商提供实现了UNDI的网卡驱动。因此UEFI网络框架的另一个形式…

亚信安慧AntDB携核心业务系统数据库升级改造方案亮相“2023年国有企业应用场景发布会”

近日&#xff0c;亚信安慧AntDB数据库携核心业务系统数据库升级改造方案亮相“2023年国有企业应用场景发布会”。本次国有企业应用场景发布会由北京市国资委主办、中关村发展集团承办、中关村软件园公司协办&#xff0c;以“融通创新 智引未来”为主题&#xff0c;聚焦智慧城市…