计算机常见算法面试题

2020-06-16 21:43

简介:计算机考研之家搜集的华为C语言经典面试题,来试试你的C语言水平吧。每道题都附有详细解答和讲解,很有参考价值的C语言面试题。

怎么判断链表中是否有环? bool CircleInList(Link* pHead) {

if(pHead = = NULL || pHead->next = = NULL)//无节点或只有一个节点并且无自环 return (false);

if(pHead->next = = pHead)//自环 return (true);

Link *pTemp1 = pHead;//step 1

Link *pTemp = pHead->next;//step 2

while(pTemp != pTemp1 && pTemp != NULL && pTemp->next != NULL) {

pTemp1 = pTemp1->next; pTemp = pTemp->next->next; }

if(pTemp = = pTemp1) return (true); return (false); }

两个字符串,s,t;把t字符串插入到s字符串中,s字符串有足够的空间存放t字符串 void insert(char *s, char *t, int i) {

memcpy(&s[strlen(t)+i],&s[i],strlen(s)-i); memcpy(&s[i],t,strlen(t)); s[strlen(s)+strlen(t)]='\\0'; }

1。编写一个 C 函数,该函数在一个字符串中找到可能的最长的子字符串,且该字符串是由同一字符组成的。

char * search(char *cpSource, char ch) {

char *cpTemp=NULL, *cpDest=NULL; int iTemp, iCount=0; while(*cpSource) {

if(*cpSource == ch) {

iTemp = 0;

cpTemp = cpSource; while(*cpSource == ch) ++iTemp, ++cpSource; if(iTemp > iCount)

iCount = iTemp, cpDest = cpTemp; if(!*cpSource) break; }

++cpSource; }

return cpDest; }

2。请编写一个 C 函数,该函数在给定的内存区域搜索给定的字符,并返回该字符所在位置索引值。

int search(char *cpSource, int n, char ch) { int i;

for(i=0; ireturn i; }

一个单向链表,不知道头节点,一个指针指向其中的一个节点,问如何删除这个指针指向的节点?

将这个指针指向的next节点值copy到本节点,将next指向next->next,并随后删除原next指向的节点。

#include

void foo(int m, int n) {

printf(\}

int main() {

int b = 3;

foo(b+=3, ++b); printf(\return 0; }

输出:m=7,n=4,b=7(VC6.0)

这种方式和编译器中得函数调用关系相关即先后入栈顺序。不过不同 编译器得处理不同。也是因为C标准中对这种方式说明为未定义,所以 各个编译器厂商都有自己得理解,所以最后产生得结果完全不同。

因为这样,所以遇见这种函数,我们首先要考虑我们得编译器会如何处理 这样得函数,其次看函数得调用方式,不同得调用方式,可能产生不同得 结果。最后是看编译器优化。

2.写一函数,实现删除字符串str1中含有的字符串str2.

第二个就是利用一个KMP匹配算法找到str2然后删除(用链表实现的话,便捷于数组)

/*雅虎笔试题(字符串操作)

给定字符串A和B,输出A和B中的最大公共子串。 比如A=\则输出\*/

//Author: azhen #include #include #include

char *commanstring(char shortstring[], char longstring[]) {

int i, j;

char *substring=malloc(256);

if(strstr(longstring, shortstring)!=NULL) //如果……,那么返回shortstring return shortstring;

for(i=strlen(shortstring)-1;i>0; i--) //否则,开始循环计算 {

for(j=0; j<=strlen(shortstring)-i; j++){ memcpy(substring, &shortstring[j], i); substring[i]='\\0';

if(strstr(longstring, substring)!=NULL) return substring; } }

return NULL; }

main() {

char *str1=malloc(256); char *str2=malloc(256); char *comman=NULL;

gets(str1); gets(str2);

if(strlen(str1)>strlen(str2)) //将短的字符串放前面 comman=commanstring(str2, str1); else

comman=commanstring(str1, str2);

printf(\}

11.写一个函数比较两个字符串str1和str2的大小,若相等返回0,若str1大于 str2返回1,若str1小于str2返回-1 int strcmp ( const char * src,const char * dst) {

int ret = 0 ;

while( ! (ret = *(unsigned char *)src - *(unsigned char *)dst) && *dst) {

++src; ++dst; }

if ( ret < 0 ) ret = -1 ;

else if ( ret > 0 ) ret = 1 ; return( ret ); }

3,求1000!的未尾有几个0(用素数相乘的方法来做,如72=2*2*2*3*3);

求出1->1000里,能被5整除的数的个数n1,能被25整除的数的个数n2,能被125整除的数的个数n3,

能被625整除的数的个数n4.

1000!末尾的零的个数=n1+n2+n3+n4; #include

#define NUM 1000

int find5(int num){ int ret=0;

while(num%5==0){ num/=5; ret++; }

return ret; }

int main(){ int result=0; int i;

for(i=5;i<=NUM;i+=5)

{

result+=find5(i); }

printf(\return 0; }

1. 有双向循环链表结点定义为: struct node { int data;

struct node *front,*next; };

有两个双向循环链表A,B,知道其头指针为:pHeadA,pHeadB,请写一函数将两链表中data值相同的结点删除

BOOL DeteleNode(Node *pHeader, DataType Value) {

if (pHeader == NULL) return;

BOOL bRet = FALSE; Node *pNode = pHead; while (pNode != NULL) {

if (pNode->data == Value) {

if (pNode->front == NULL) {

pHeader = pNode->next; pHeader->front = NULL; } else {

if (pNode->next != NULL) {

pNode->next->front = pNode->front; }

pNode->front->next = pNode->next; }

Node *pNextNode = pNode->next; delete pNode;

pNode = pNextNode;


计算机常见算法面试题.doc 将本文的Word文档下载到电脑 下载失败或者文档不完整,请联系客服人员解决!

下一篇:ComMonitor捷通串口调试软件使用手册

相关阅读
本类排行
× 注册会员免费下载(下载后可以自由复制和排版)

马上注册会员

注:下载文档有可能“只有目录或者内容不全”等情况,请下载之前注意辨别,如果您已付费且无法下载或内容有问题,请联系我们协助你处理。
微信: QQ: