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

前面总结了有关字符串和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

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Spring Boot 整合多 Redis 数据源配置及操作

Spring Boot 整合多 Redis 数据源配置及操作 简介 本文档介绍了如何在Spring Boot应用程序中配置和操作多个Redis数据源。通过配置多个RedisConnectionFactory和RedisTemplate&#xff0c;可以实现对多个Redis数据源的整合&#xff0c;以便在应用程序中灵活地使用不同的Redis…

windows2012 安装mysql5.7

windows2012 安装mysql5.7 1.安装1.解压文件夹2.把my文件拷入没有sql安装目录3.编辑my文件4.按照下方进行配置5.cmd进入bin目录6.出现丢失文件7.安装这个文件即可解决8.开始进行安装&#xff0c;输入mysqld install9.初始化mysql&#xff08;mysqld --initialize --console&…

python识别验证码+灰度图片base64转换图片

一、为后面识别验证码准备 1、图片base64转换为 上文中的base64,后面的就是包含Base64编码的PNG图像的字符串复制下来 import base64 from PIL import Image import io# 这里是你的Base64编码的字符串 base64_data "iVBORw0KGgoAAAANSUhEUgAAAG8AAAAkCAIAAAAIOPOYAAAJ1E…

提供电商Api接口-100种接口,淘宝,1688,抖音商品详情数据安全,稳定,支持高并发

Java是一种高级编程语言&#xff0c;由Sun Microsystems公司于1995年推出&#xff0c;现在属于Oracle公司开发和维护。Java以平台无关性、面向对象、安全性、可移植性和高性能著称&#xff0c;广泛用于桌面应用程序、嵌入式系统、企业级服务、Android移动应用程序等。 接口是Ja…

软件测试方法分类-按测试对象划分

接上一篇,下来我们再细讲,第四个维度的分类, 软件测试方法分类-按测试对象划分 本章节重点介绍非功能测试的相关知识,因为功能测试的基本在之前的分类都是有涉及的。 一、非功能测试 1,性能测试(Performance Testing) 检查系统是否满足需求规格说明书中规定的性能。 …

Clion STM32 开发环境配置教程

Clion STM32 开发环境配置教程 STM32 CubeMX&#xff08;6.5&#xff09; 下载固件库 若固件库还未下载&#xff0c;可在启动界面点击&#xff0c;INSTALL/REMOVE下载所需要的固件库 选中对应固件库&#xff0c;点击Install即可 Clion&#xff08;2023.3.1&#xff09; 略 …

从零实现一套低代码(保姆级教程) --- 【14】实现头像组件和徽标容器

前话 文章开始前&#xff0c;先解决一下之前的某个错误。 在InputComponent中&#xff0c;如果是弹窗类型的组件&#xff0c;我们点击按钮会把ModalComponent组件弹出来。同时&#xff0c;我们要把key传进去。 return (<div>{getComponent()}// 把valueKey穿过去<Mo…

Java集合框架和泛型

1.Java集合框架 架构图&#xff1a; Java的集合框架是一组用于存储和操作数据的类和接口。它提供了各种数据结构&#xff0c;如列表、集合、映射等&#xff0c;以及用于操作这些数据结构的算法和工具。Java集合框架位于Java.util包中&#xff0c;并且是Java编程中常用的核心组…

软件质效领航者!ONES 获中国信通院「软件质效技术创新」优秀案例奖

近日&#xff0c;由中国信息通信研究院、中国通信标准化协会联合主办的 2023 系统稳定性与精益软件工程大会-AI 赋能软件质效专场暨云上软件工程社区年会在北京召开&#xff0c;会上正式公布了第二届「软件质效领航者」优秀案例的评选结果。 凭借产品及服务的成熟度、典范性和…

thinkcmf 配置移动端模板

1.找到tinkcmf/data/config/template.php 文件 cmf_moblie_default_theme > cffff_m, 2. 找到thinkcmf/vendor/thinkcmf/src/common.php // $theme config(template.cmf_default_theme);if (cmf_is_mobile()) {$theme config(template.cmf_moblie_default_theme);} el…

python股票分析挖掘预测技术指标知识之均线指标详解(6)

本人股市多年的老韭菜&#xff0c;各种股票分析书籍&#xff0c;技术指标书籍阅历无数&#xff0c;萌发想法&#xff0c;何不自己开发个股票预测分析软件&#xff0c;选择python因为够强大&#xff0c;它提供了很多高效便捷的数据分析工具包。 我们已经初步的接触与学习其中数…

计算机毕业论文内容参考|基于区块链技术的电子健康记录系统的设计与实现

文章目录 摘要前言绪论课题背景国内外相关研究课题内容区块链技术介绍系统分析用户需求分析系统设计系统实现系统测试总结与展望摘要 本文介绍了基于区块链技术的电子健康记录系统的设计与实现。该系统旨在解决传统电子健康记录系统存在的数据安全性、数据隐私性和数据互操作性…

【springboot+mybatis实现CURD模版项目-Jesus】

springbootmybatis实现CURD模版项目-Jesus STEP 1 项目创建 1.1 新建Spring Initializr项目   1.2 选择需要的依赖 springboot有2.7.2直接选272STEP 2 配置更改 2.1更改maven配置   2.2 检查项目配置jdk、sdk、jre版本一致   2.3 检查pom文件&#xff0c;Maven-Reload pr…

鸿蒙OpenHarmony技术—消息机制实现

用户态应用发送消息到驱动 用户态主要代码 struct HdfIoService *serv HdfIoServiceBind(SAMPLE_SERVICE_NAME);......ret serv->dispatcher->Dispatch(&serv->object, SAMPLE_WRITE_READ, data, reply); if (ret ! HDF_SUCCESS) {HDF_LOGE("fail to sen…

通往人工智能的 Go 之路

Agency 该库旨在为那些希望通过清晰、高效且符合 Go 语言惯例的方法来探索大型语言模型&#xff08;LLMs&#xff09;和其他生成式人工智能的开发人员而设计。 特点 纯 Go 语言&#xff1a;快速、轻量级&#xff0c;静态类型&#xff0c;无需涉及 Python 或 JavaScript编写清晰…

人工智能趋势报告解读:ai野蛮式生长的背后是机遇还是危机?

近期&#xff0c;Enterprise WordPress发布了生成式人工智能在营销中的应用程度的报告&#xff0c;这是一个人工智能迅猛发展的时代&#xff0c;目前人工智能已经广泛运用到内容创作等领域&#xff0c;可以预见的是人工智能及其扩展应用还将延伸到我们工作与生活中的方方面面。…

gradle --腾讯国内镜像源

distributionUrlhttps\://mirrors.cloud.tencent.com/gradle/gradle-7.3.3-bin.zip 1.进入到自己工程目录下的wrapper文件夹。 2.编辑gradle-wrapper文件 使用https://mirrors.cloud.tencent.com/gradle/gradle-4.6-all.zip来代替原来的 https\://services.gradle.org/distri…

高精度、大电流、低压差电压调整器芯片 D2632,可以用于电池供电设备等产品上

D2632是一款高精度、大电流、低压差电压调整器。主要作为电源装置提供高效的电压调整。 最大输出电流可达3A&#xff0c;并且外接器件少&#xff0c;拥有输出电压(ADJ) 可调特点。 主要特点&#xff1a; 1. 低压差(满载350mV); 2. 地电流小; …

Oracle导出CSV文件

利用spool spool基本格式&#xff1a; spool 路径文件名 select col1||,||col2||,||col3||,||col4 from tablename; spool off spool常用的设置&#xff1a; set colsep ;    //域输出分隔符 set echo off;    //显示start启动的脚本中的每个sql命令&#xff0c;缺…

利用Embedding优化搜索功能

我们继续用Gemini学习LLM编程之旅。 Embedding是一种自然语言处理 (NLP) 技术&#xff0c;可将文本转换为数值向量。Embedding捕获语义含义和上下文&#xff0c;从而导致具有相似含义的文本具有更接近的Embedding。例如&#xff0c;句子“我带我的狗去看兽医”和“我带我的猫去…