【Leetcode】NC31 第一个只出现一次的字符(牛客网)、面试题 01.01. 判定字符是否唯一
创始人
2024-05-12 23:31:06

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

专栏:《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. 判定字符是否唯一

面试题 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;
}


相关内容

热门资讯

demo什么意思 demo版本... 618快到了,各位的小金库大概也在准备开闸放水了吧。没有小金库的,也该向老婆撒娇卖萌服个软了,一切只...
苗族的传统节日 贵州苗族节日有... 【岜沙苗族芦笙节】岜沙,苗语叫“分送”,距从江县城7.5公里,是世界上最崇拜树木并以树为神的枪手部落...
北京的名胜古迹 北京最著名的景... 北京从元代开始,逐渐走上帝国首都的道路,先是成为大辽朝五大首都之一的南京城,随着金灭辽,金代从海陵王...