【Leetcode】NC31 第一个只出现一次的字符(牛客网)、面试题 01.01. 判定字符是否唯一

简介: 题目描述:描述在一个长为n字符串中找到第一个只出现一次的字符,并返回它的位置, 如果没有则返回 -1(需要区分大小写).(从0开始计数)

作者:一个喜欢猫咪的的程序员

专栏:《Leetcode》

喜欢的话:世间因为少年的挺身而出,而更加瑰丽。                                  ——《人民日报》


NC31 第一个只出现一次的字符

https://www.nowcoder.com/practice/1c82e8cf713b4bbeb2a5b31cf5b0417c?tpId=188&&tqId=38575&rp=1&ru=/activity/oj&qru=/ta/job-code-high-week/question-ranking#:~:text=%E4%B8%8B%E4%B8%80%E9%A2%98-,NC31%20%E7%AC%AC%E4%B8%80%E4%B8%AA%E5%8F%AA%E5%87%BA%E7%8E%B0%E4%B8%80%E6%AC%A1%E7%9A%84%E5%AD%97%E7%AC%A6,-%E9%A2%98%E7%9B%AE

题目描述:

描述

在一个长为n字符串中找到第一个只出现一次的字符,并返回它的位置, 如果没有则返回 -1(需要区分大小写).(从0开始计数)

数据范围:0≤n≤100000≤n≤10000,且字符串只有字母组成。

示例:


思路:

我们将每个字符分别进行向前找相同字符和向后找相同字符,如果找到将num设为-1,判断num是否等于-1来判断是否跳出循环。

代码:

int FirstNotRepeatingChar(char* str) {
    int num = 0;
    for (int i = 0; i < strlen(str); i++)
    {
        if (num == -1)
        {
            num = i;
        }
        for (int j = 0; j < i; j++)
        {
            if (str[j] == str[i])
            {
                num = -1;
                break;
            }
        }
        if (num == -1&&i==strlen(str)-1)
        {
            break;
        }
        int n = i;
        while (n < strlen(str))
        {
            if (str[n + 1] == str[i])
            {
                num = -1;
                break;
            }
            n++;
        }
        if (num != -1)
        {
            return num;
        }
    }
    return-1;
}



面试题 01.01. 判定字符是否唯一

https://leetcode.cn/problems/is-unique-lcci/

题目描述:

实现一个算法,确定一个字符串 s 的所有字符是否全都不同。

示例:


思路:

还是向前和向后判断是否有相同的字符,如果有直接返回false。

注意几种极端情况:

1.字符只有一个的时候,直接判断,

2.当下标遍历走到字符串长度-1的位置注意越界的情况。

代码:

bool isUnique(char* astr) {
    int cur = 0;
    int flag = 0;
    if (strlen(astr) == 1)//避免astr的长度为1的特殊情况
        return true;
    while (cur < strlen(astr))
    {
        for (int i = 0; i < cur; i++)//向前判断相等
        {
            if (astr[i] == astr[cur])
            {
                flag = 1;
                break;
            }
        }
        int n = cur;//向后判断相等
        while (n < strlen(astr))
        {
            if (n + 1 <= strlen(astr) && astr[cur] == astr[n + 1])//避免越界
            {
                flag = 1;
                break;
            }
            n++;
        }
        if (flag == 1)
        {
            return false;
        }
        cur++;
    }
    return true;
}
相关文章
|
1月前
|
存储 算法
Leetcode第三题(无重复字符的最长子串)
这篇文章介绍了解决LeetCode第三题“无重复字符的最长子串”的算法,使用滑动窗口技术来找出给定字符串中最长的不含重复字符的子串,并提供了详细的代码实现和解释。
65 0
Leetcode第三题(无重复字符的最长子串)
|
3月前
|
算法
LeetCode第3题无重复字符的最长子串
该文章介绍了 LeetCode 第 3 题无重复字符的最长子串的解法,通过使用 HashSet 记录不重复的子元素,以每个字符开头遍历字符串,遇到重复字符则重新计算,最终找到最长子串,同时提到可以考虑使用 HashMap 降低复杂度。
LeetCode第3题无重复字符的最长子串
|
4月前
|
Python
155. 最小栈 力扣 python 空间换时间 o(1) 腾讯面试题
155. 最小栈 力扣 python 空间换时间 o(1) 腾讯面试题
|
4月前
|
存储 算法 索引
1124. 表现良好的最长时间段 (python) 前缀和 分类讨论 最大长度 力扣 面试题
1124. 表现良好的最长时间段 (python) 前缀和 分类讨论 最大长度 力扣 面试题
|
4月前
|
存储 算法
经典的滑动窗口的题目 力扣 2799. 统计完全子数组的数目(面试题)
经典的滑动窗口的题目 力扣 2799. 统计完全子数组的数目(面试题)
|
4月前
|
索引
821.字符的最短距离-力扣(LeetCode)
821.字符的最短距离-力扣(LeetCode)
32 0
|
5月前
|
存储 算法 程序员
力扣经典150题第三十一题:无重复字符的最长子串
力扣经典150题第三十一题:无重复字符的最长子串
31 0
|
5月前
【LeetCode刷题】滑动窗口思想解决问题:长度最小的子数组、无重复字符的最长子串
【LeetCode刷题】滑动窗口思想解决问题:长度最小的子数组、无重复字符的最长子串
|
5月前
|
SQL 算法 大数据
深入解析力扣181题:超过经理收入的员工(自连接方法详解及模拟面试问答)
深入解析力扣181题:超过经理收入的员工(自连接方法详解及模拟面试问答)
|
2月前
|
Unix Shell Linux
LeetCode刷题 Shell编程四则 | 194. 转置文件 192. 统计词频 193. 有效电话号码 195. 第十行
本文提供了几个Linux shell脚本编程问题的解决方案,包括转置文件内容、统计词频、验证有效电话号码和提取文件的第十行,每个问题都给出了至少一种实现方法。
LeetCode刷题 Shell编程四则 | 194. 转置文件 192. 统计词频 193. 有效电话号码 195. 第十行