【剑指offer】第一个仅仅出现一次的字符

转载请注明出处:http://blog.csdn.net/ns_code/article/details/27106997

题目描写叙述:

在一个字符串(1<=字符串长度<=10000,所有由大写字母组成)中找到第一个仅仅出现一次的字符。

输入:

输入有多组数据
每一组输入一个字符串。

输出:

输出第一个仅仅出现一次的字符下标,没有仅仅出现一次的字符则输出-1。

例子输入:
ABACCDEFF
AA
例子输出:
1
-1

处理字符串中反复或者次数出现等问题,最经常使用的就是哈希表,用字符串中的字符作为key,字符出现次数作为value,假定仅仅有ASCII码范围内的字符,则能够开辟一个256大小的int数组,将每一个字符(key)映射到该数组的相应位置上,计算每次出现的次数就可以,遍历一次字符串,计算每一个字符出现的次数,保存在int数组的相应位置上,第二次遍历字符串,若第一次出现某个字符对相应到的哈希表的相应位置处的元素为1,则该字符便是第一个仅仅出现一次的字符,假设我们是遍历哈希表(int数组),则找到的哈希表中的第一个元素为1的位置相应的字符为字符串中第一个最小的仅仅出现一次的字符。时间复杂度为O(n),须要额外的256个int空间来辅助,能够看做空间复杂度为O(1)。

另外,假设要省空间,我们能够bitmap算法,用两个位来表示相应字符出现的次数,出现0次,则为00,出现一次则为01,出现2次及以上,都维持在10就可以。

另外,有一点须要注意,char的范围在-128-127,unsigned char的范围才是在0-255,因此ASCII值在128-255之间的字符,假设保存为了char型,其转化为int值的范围是在-128--1之间,这点在以下的代码中有体现。

以下给出用简单哈希表AC的代码(依据题目要求和測试要求分别写了两个函数):

#include<stdio.h>
#include<string.h>

/*
返回第一个出现一次的字符
*/
char FirstOnceChar(char *str)
{
	if(str == NULL)
		return ‘\0‘;

	int hashtable[256];
	memset(hashtable,0,sizeof(hashtable));
	char *pCur = str;
	while(*pCur != ‘\0‘)
	{
		if(*pCur>=0)
			hashtable[*(pCur++)]++;
		else
			hashtable[*(pCur++)+256]++;
	}

	while(*str != ‘\0‘)
	{
		int index;
		if(*str>=0)
			index = *str;
		else
			index = *str+256;

		if(hashtable[index] == 1)
			return *str;
		else
			str++;
	}
	return ‘\0‘;
}

/*
返回第一个出现一次的字符的下标
*/
int IndexOfFirstOnceChar(char *str)
{
	if(str == NULL)
		return -1;

	int len = strlen(str);
	int hashtable[256];
	memset(hashtable,0,sizeof(hashtable));
	int i;
	for(i=0;i<len;i++)
	{
		if(str[i]>=0)
			hashtable[str[i]]++;
		else
			hashtable[str[i]+256]++;
	}

	for(i=0;i<len;i++)
	{
		int index;
		if(str[i]>=0)
			index = str[i];
		else
			index = str[i]+256;

		if(hashtable[index] == 1)
			return i;
	}
	return -1;
}

int main()
{
	char str[10010];
	while(gets(str) != NULL)
		printf("%d\n",IndexOfFirstOnceChar(str));
	return 0;
}

/**************************************************************

    Problem: 1283

    User: mmc_maodun

    Language: C

    Result: Accepted

    Time:10 ms

    Memory:912 kb

****************************************************************/

时间: 2024-10-10 00:48:18

【剑指offer】第一个仅仅出现一次的字符的相关文章

剑指Offer - 第一个只出现一次的字符位置

https://www.nowcoder.com/practice/1c82e8cf713b4bbeb2a5b31cf5b0417c?tpId=13&tqId=11187&tPage=2&rp=2&ru=/ta/coding-interviews&qru=/ta/coding-interviews/question-ranking 题目描述 在一个字符串(1<=字符串长度<=10000,全部由字母组成)中找到第一个只出现一次的字符,并返回它的位置 代码

剑指Offer——第一个只出现一次的字符

1.题目描述 在一个字符串(0<=字符串长度<=10000,全部由字母组成)中找到第一个只出现一次的字符,并返回它的位置, 如果没有则返回 -1(需要区分大小写). 2.代码实现 public class Solution { public int FirstNotRepeatingChar(String str) { if (str == null || str.length() == 0) { return -1; } char[] chars = str.toCharArray(); j

剑指 offer 第一题: 二维数组中的查找

打算写 图解剑指 offer 66 题 的系列文章,不知道大家有没有兴趣 ?? 题目描述 在一个二维数组中(每个一维数组的长度相同),每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序.请完成一个函数,输入这样的一个二维数组和一个整数,判断数组中是否含有该整数. 题目分析 图 1 如果没有头绪的话,很显然使用 暴力解法 是完全可以解决该问题的. 即遍历二维数组中的每一个元素,时间复杂度:O(n^2). 其实到这里我们就可以发现,使用这种暴力解法并没有充分利用题目给出的信息.这

《剑指offer》第五十题II:字符流中第一个只出现一次的字符

// 面试题50(二):字符流中第一个只出现一次的字符 // 题目:请实现一个函数用来找出字符流中第一个只出现一次的字符.例如,当从 // 字符流中只读出前两个字符"go"时,第一个只出现一次的字符是'g'.当从该字 // 符流中读出前六个字符"google"时,第一个只出现一次的字符是'l'. #include <cstdio> #include <vector> #include <limits> using namespac

剑指Offer-33.第一个只出现一次的字符(C++/Java)

题目: 在一个字符串(0<=字符串长度<=10000,全部由字母组成)中找到第一个只出现一次的字符,并返回它的位置, 如果没有则返回 -1(需要区分大小写). 分析: 遍历字符串,利用Hashmap将每一个字符出现的值存储起来,然后再遍历字符串,返回第一个字符值为1的索引即可. 程序: C++ class Solution { public: int FirstNotRepeatingChar(string str) { for(int i = 0; i < str.size(); ++

剑指offer第一题:二维数组的查找(python)

题目描述: 在一个二维数组中(每个一维数组的长度相同),每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序.请完成一个函数,输入这样的一个二维数组和一个整数,判断数组中是否含有该整数. 思路: 应当从数组的左下角或右上角开始判断,以左下角为例,若整数小于左下角数值,则最后一行不用考虑.若整数大于左下角数值,则第一列不用考虑.不断缩小范围. 1 # -*- coding:utf-8 -*- 2 class Solution: 3 # array 二维列表 4 def Find(

二维数组的查找——剑指offer第一题

题目描述: 在一个二维数组中(每个一维数组的长度相同), 每一行都按照从左到右递增的顺序排序, 每一列都按照从上到下递增的顺序排序. 请完成一个函数,输入这样的一个二维数组和一个整数,判断数组中是否含有该整数. 设计思路: 遍历所有行 遍历行中的每个元素 判断元素值是否与给定的target值相等 相等返回True 判断元素是否大于给定target值(比target值大的话跳出循环) 遍历完没有返回false 代码: 1 import numpy as np 2 class Solution: 3

剑指offer第一题:二维数组中的查找

题目:在一个二维数组中(每个一维数组的长度相同),每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序.请完成一个函数,输入这样的一个二维数组和一个整数,判断数组中是否含有该整数. 菜鸡解法...O(nlogm) 1 public class Solution { 2 public boolean Find(int target, int [][] array) { 3 int row = array.length;//二维数组行数 4 int col = array[0].l

【剑指Offer第一题】二维数组的查找

题目描述在一个二维数组中(每个一维数组的长度相同),每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序.请完成一个函数,输入这样的一个二维数组和一个整数,判断数组中是否含有该整数. 注:设二维数组为m行n列.语言:C++ 解法1:顺序查找 bool Find(int target, vector<vector<int> > array) { vector<vector<int> >::iterator i; vector<int&g

剑指Offer33 第一个只出现一次的字符

1 /************************************************************************* 2 > File Name: 33_FirstNotRepeatChar.c 3 > Author: Juntaran 4 > Mail: [email protected] 5 > Created Time: 2016年09月02日 星期五 13时43分20秒 6 ********************************