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++;
}
}
}