C语言日记 2024年10月30日

目录

总结:

头文件:

函数:

内容:


总结:

头文件:

前三个函数来自于<string.h>

malloc来自于<stdlib.h>

函数:

strcmp(s1,s2);

用来比较字符串,s1大于s2时返回大于0的数。(同理,相同的话就等于0,小于的话就小于0。)

strlen(s1);

用来获得字符串的长度。

strcpy(s1,s2);

将字符串s2的内容复制给s1。

s1=(char*)malloc(n);

用来给s1这个字符串n位内存空间。

内容:

今天看见了一道题,题目如下。

复制代码
3216. 交换后字典序最小的字符串
简单
提示
给你一个仅由数字组成的字符串 s,在最多交换一次 相邻 且具有相同 奇偶性 的数字后,返回可以得到的
字典序最小的字符串
。

如果两个数字都是奇数或都是偶数,则它们具有相同的奇偶性。例如,5 和 9、2 和 4 奇偶性相同,而 6 和 9 奇偶性不同。

示例 1:

输入: s = "45320"

输出: "43520"

解释:

s[1] == '5' 和 s[2] == '3' 都具有相同的奇偶性,交换它们可以得到字典序最小的字符串。

示例 2:

输入: s = "001"

输出: "001"

解释:

无需进行交换,因为 s 已经是字典序最小的。

其中"字典序"我不知道是啥。

我认为字典序就是你查字典的时候,不同字在字典里的排序。例如用拼音查字法里的pa的字典序就比pi要靠前(也就是小。)。

接下来说说我的解题思路。

我的思路是穷举,通过获得全部的结果,然后比大小,将最小的结果返回回去就可以了。

这里用到的关键函数是strcmp,它用来进行比较字符串大小的操作。

我的答案如下。

复制代码
char* getSmallestString(char* s) {
    int len=strlen(s);//获取字符串长度
    if(len<2)
    {
        return s;
    }
    int i=0;
    char* r1;
    r1 = (char *)malloc(sizeof(char)*(len+1));
    strcpy(r1,s);
    char* r2;
    r2 = (char *)malloc(sizeof(char)*(len+1));
    for(i=0;(i+1)<=(len-1);i++)
    {
        int num1 = s[i]-'0';
        int num2 = s[i+1]-'0';
        char temp;
        if ((num1%2==num2%2))
        {
            strcpy(r2,s);
            r2[i+1]=s[i];
            r2[i]=s[i+1];
            if(strcmp(r2,r1)<0)
            {
             strcpy(r1,r2);
            }
        }
    }
    return r1;
}
相关推荐
报错小能手34 分钟前
数据结构 字典树
开发语言·数据结构
XLYcmy43 分钟前
高级密码生成器程序详解:专门设计用于生成基于用户个人信息的密码猜测组合
开发语言·数据结构·python·网络安全·数据安全·源代码·口令安全
AI科技星1 小时前
时空的固有脉动:波动方程 ∇²L = (1/c²) ∂²L/∂t² 的第一性原理推导、诠释与验证
数据结构·人工智能·算法·机器学习·重构
2401_841495641 小时前
【LeetCode刷题】寻找重复数
数据结构·python·算法·leetcode·链表·数组·重复数
Joe_Blue_022 小时前
Matlab入门案例介绍—常用的运算符及优先级
开发语言·数据结构·matlab·matlab基础入门案例介绍
C雨后彩虹2 小时前
二维伞的雨滴效应
java·数据结构·算法·华为·面试
一路往蓝-Anbo2 小时前
C语言从句柄到对象 (八) —— 当对象会说话:观察者模式与事件链表
c语言·开发语言·数据结构·stm32·单片机·观察者模式·链表
youngee112 小时前
hot100-60子集
数据结构·算法
郝学胜-神的一滴3 小时前
Linux线程属性设置分离技术详解
linux·服务器·数据结构·c++·程序人生·算法
清水白石0084 小时前
《Python 中 deque vs list:性能差异全解析与高效数据结构实战指南》
数据结构·python·list