算法面试题
2014-05-02 19:42
92 查看
华为2014校园招聘的机试题目和2013年的完全一样。
一、题目描述(60分):
通过键盘输入一串小写字母(a~z)组成的字符串。请编写一个字符串过滤程序,若字符串中出现多个相同的字符,将非首次出现的字符过滤掉。
比如字符串“abacacde”过滤结果为“abcde”。
要求实现函数:void stringFilter(const char *pInputStr, long lInputLen, char *pOutputStr);
【输入】 pInputStr: 输入字符串
lInputLen: 输入字符串长度
【输出】 pOutputStr: 输出字符串,空间已经开辟好,与输入字符串等长;
【注意】只需要完成该函数功能算法,中间不需要有任何IO的输入输出
示例
输入:“deefd” 输出:“def”
输入:“afafafaf” 输出:“af”
输入:“pppppppp” 输出:“p”
main函数已经隐藏,这里保留给用户的测试入口,在这里测试你的实现函数,可以调用printf打印输出
当前你可以使用其他方法测试,只要保证最终程序能正确执行即可,该函数实现可以任意修改,但是不要改变函数原型。一定要保证编译运行不受影响
#include<stdio.h>
#include<malloc.h>
#include<stdlib.h>
#include<string.h>
#define M 1000
int a[26];
int check(const char ch)
{
int n;
n=(int )ch;
n=n-97;
if(a[n%26]==0)
{
a[n%26]=1;
return 1;
}else{
return 0;
}
}
void stringFilter(const char *pInputStr, long lInputLen, char *pOutputStr)
{
/// int c;
int i=0;
while(*pInputStr!='\0')
{
if(1==check(*pInputStr))
{
pOutputStr[i++]=*pInputStr;
}
pInputStr++;
}
pOutputStr[i]='\0';
}
long length(const char *pInputStr)
{
const char *p;
long len=0;
p=pInputStr;
while(*p!='\0')
{
p=++p;
len++;
}
return len;
}
int main()
{
const char *pInputStr;
char *pOutputStr;
long lInputLen=0;
memset(a,0,sizeof(a));
pInputStr=(char *)malloc(sizeof(char)*M);
scanf("%s",pInputStr);
lInputLen=length(pInputStr);
pOutputStr=(char *)malloc(sizeof(char)*lInputLen);
stringFilter(pInputStr,lInputLen,pOutputStr);
printf("%d\n",lInputLen);
printf("%s\n",pOutputStr);
return 0;
}
一、题目描述(60分):
通过键盘输入一串小写字母(a~z)组成的字符串。请编写一个字符串过滤程序,若字符串中出现多个相同的字符,将非首次出现的字符过滤掉。
比如字符串“abacacde”过滤结果为“abcde”。
要求实现函数:void stringFilter(const char *pInputStr, long lInputLen, char *pOutputStr);
【输入】 pInputStr: 输入字符串
lInputLen: 输入字符串长度
【输出】 pOutputStr: 输出字符串,空间已经开辟好,与输入字符串等长;
【注意】只需要完成该函数功能算法,中间不需要有任何IO的输入输出
示例
输入:“deefd” 输出:“def”
输入:“afafafaf” 输出:“af”
输入:“pppppppp” 输出:“p”
main函数已经隐藏,这里保留给用户的测试入口,在这里测试你的实现函数,可以调用printf打印输出
当前你可以使用其他方法测试,只要保证最终程序能正确执行即可,该函数实现可以任意修改,但是不要改变函数原型。一定要保证编译运行不受影响
#include<stdio.h>
#include<malloc.h>
#include<stdlib.h>
#include<string.h>
#define M 1000
int a[26];
int check(const char ch)
{
int n;
n=(int )ch;
n=n-97;
if(a[n%26]==0)
{
a[n%26]=1;
return 1;
}else{
return 0;
}
}
void stringFilter(const char *pInputStr, long lInputLen, char *pOutputStr)
{
/// int c;
int i=0;
while(*pInputStr!='\0')
{
if(1==check(*pInputStr))
{
pOutputStr[i++]=*pInputStr;
}
pInputStr++;
}
pOutputStr[i]='\0';
}
long length(const char *pInputStr)
{
const char *p;
long len=0;
p=pInputStr;
while(*p!='\0')
{
p=++p;
len++;
}
return len;
}
int main()
{
const char *pInputStr;
char *pOutputStr;
long lInputLen=0;
memset(a,0,sizeof(a));
pInputStr=(char *)malloc(sizeof(char)*M);
scanf("%s",pInputStr);
lInputLen=length(pInputStr);
pOutputStr=(char *)malloc(sizeof(char)*lInputLen);
stringFilter(pInputStr,lInputLen,pOutputStr);
printf("%d\n",lInputLen);
printf("%s\n",pOutputStr);
return 0;
}
相关文章推荐
- 微软的22道数据结构算法面试题(含答案)
- 算法经典面试题整理(java实现)
- 算法与数据结构面试题(19)-统计字符串中的字符个数
- 九章算法面试题86 合并排序数组
- 非常有用的101道算法部分常见面试题
- 经典算法面试题系列 (二)——three sum
- 经典面试题(一)附答案 算法+数据结构+代码 微软Microsoft、谷歌Google、百度、腾讯
- 微软、Google等面试题、算法
- 腾讯算法面试题
- 【面试题之算法部分】LCA最近公共祖先
- 算法和编程面试题
- 经典基础算法之面试题(系列一)(转)
- 算法面试题
- 腾讯算法面试题
- 数据挖掘算法面试题
- [面试题]设计一个算法找到数组中两个元素相加等于指定数的所有组合
- 面试题11 - 字符串的排列[算法]
- 一道博弈的面试题及其算法正确性证明
- 算法面试题-美团点评2016研发工程师编程题(二)-字符编码(哈夫曼树)
- 经典面试题(四)附答案 算法+数据结构+代码 微软Microsoft、谷歌Google、百度、腾讯