劍指offer--簡易哈希表(13、36、57)

offer13

在一個字符串中找到第一個只出現一次的字符。如輸入abaccdeff,則輸出b

可以採用256的一個數組存儲字符出現的次數,因爲只有256個字符。先遍歷一遍字符串更新數組信息,然後再從頭遍歷字符串,找到數組中值爲1的第一個字符即可。


char find(char *a)
{
	int n=strlen(a);
	int sign[256]={0};
	int i;
	for(i=0;i<n;i++)
	{
		sign[(int)a[i]]++;
	}
	for(i=0;i<n;i++)
	{
		if(sign[(int)a[i]]==1)
			return a[i];
	}
}

offer36

輸入兩個字符串,從第一字符串中刪除第二個字符串中所有的字符。例如,輸入”They are students.””aeiou”,則刪除之後的第一個字符串變成”Thy r stdnts.”

和上一題一樣,想把第二個字符串的信息存到數組中,然後在刪除。

刪除的時候可以採用兩個指針,第二個指針跳過要刪除的字符,第一個指針用來存放第二個指針遍歷的字符,記得最後要更新 '\0'。

void DeleteChars(char *str1, char *str2)
{
	bool sign[256]={0};
	int len1=strlen(str1);
	int len2=strlen(str2);

	int i,j;
	for (i=0; i<len2; i++)
	{
		sign[(int)(str2[i])]=true;
	}

	char *pNow,*plast;
	pNow=plast=str1;
	while (*plast!='\0')
	{
		if (!sign[(int)(*plast)])
		{
			*pNow=*plast;
			pNow++;
			plast++;
		}
		else
		{
			plast++;
		}
	}
	*pNow='\0';
}

offer57

某公司有幾萬名員工,請完成一個時間複雜度爲O(n)的算法對該公司員工的年齡作排序,可使用O(1)的輔助空間。

題目中隱含着年齡的範圍,同第一題

bool SortAges(int *age, int len)
{
	if (!age || len<0)
		return false;

	int ageSign[101]={0};
	int i, j;
	for (i=0; i<len; i++)
	{
		if(age[i]<0 || age[i]>100)
			return false;
		ageSign[age[i]]++;
	}

	for (i=0, j=0; i<=100; i++)
	{
		while (ageSign[i]!=0)
		{
			age[j]=i;
			ageSign[i]--;
			j++;
		}
	}
}


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章