十年網(wǎng)站開發(fā)經(jīng)驗 + 多家企業(yè)客戶 + 靠譜的建站團隊
量身定制 + 運營維護+專業(yè)推廣+無憂售后,網(wǎng)站問題一站解決
這篇文章主要介紹了如何用C語言棧和隊列實現(xiàn)回文檢測功能的相關知識,內(nèi)容詳細易懂,操作簡單快捷,具有一定借鑒價值,相信大家閱讀完這篇如何用C語言棧和隊列實現(xiàn)回文檢測功能文章都會有所收獲,下面我們一起來看看吧。
10年的五華網(wǎng)站建設經(jīng)驗,針對設計、前端、開發(fā)、售后、文案、推廣等六對一服務,響應快,48小時及時工作處理。營銷型網(wǎng)站建設的優(yōu)勢是能夠根據(jù)用戶設備顯示端的尺寸不同,自動調(diào)整五華建站的顯示方式,使網(wǎng)站能夠適用不同顯示終端,在瀏覽器中調(diào)整網(wǎng)站的寬度,無論在任何一種瀏覽器上瀏覽網(wǎng)站,都能展現(xiàn)優(yōu)雅布局與設計,從而大程度地提升瀏覽體驗。創(chuàng)新互聯(lián)公司從事“五華網(wǎng)站設計”,“五華網(wǎng)站推廣”以來,每個客戶項目都認真落實執(zhí)行。
具體代碼如下:
#include#include //內(nèi)存分配頭文件 #include //在math.h中已定義OVERFLOW的值為3 #define SIZE 100 #define STACKINCREMENT 10 #define OK 1 #define ERROR 0 #define TRUE 1 #define FALSE 0 typedef int Status; typedef struct //棧的結(jié)構(gòu)體 { char a; } SElemType; typedef struct { SElemType *base; SElemType *top; int stacksize; } SqStack; typedef struct //QNode //隊列的結(jié)構(gòu)體 { char b; struct QNode * next; } QNode,*QueuePtr; typedef struct // 鏈隊列類型 { QueuePtr front; // 隊頭指針 QueuePtr rear; // 隊尾指針 } LinkQueue; //定義全局變量 SqStack S; SElemType e; LinkQueue Q; QueuePtr p; char f; //棧操作 Status InitStack(SqStack *S) { S->base=(SElemType *)malloc(SIZE*sizeof(SElemType)); if(!S->base) exit(OVERFLOW); S->top=S->base; S->stacksize=SIZE; return OK; } Status Push(SqStack *S,SElemType e) { if(S->top-S->base>=S->stacksize) { S->base=(SElemType *)malloc((S->stacksize+STACKINCREMENT)*sizeof(SElemType)); if(!S->base) exit(OVERFLOW); S->top=S->base+S->stacksize; S->stacksize+=STACKINCREMENT; } *S->top++=e; return OK; } Status Stackempty(SqStack S)//棧是否為空 { if(S.top==S.base) return TRUE; else return FALSE; } Status Pop(SqStack *S,SElemType *e) { if(S->top==S->base) return ERROR; *e=*--S->top; return OK; } Status StackLength(SqStack S)//求棧的長度 { return (S.top-S.base); } //隊列操作 Status InitQueue(LinkQueue *Q) { Q->front=(QueuePtr)malloc(sizeof(QNode)); Q->rear=Q->front; if(!Q->front) exit(OVERFLOW); Q->front->next=NULL; return OK; } Status EnQueue(LinkQueue *Q,char f) { p=(QueuePtr)malloc(sizeof(QNode)); if(!p) exit(OVERFLOW); p->b=f; p->next=NULL; Q->rear->next=p; Q->rear=p; return OK; } Status DeQueue(LinkQueue *Q,char *f) { if(Q->front==Q->rear) return ERROR; p=Q->front->next; *f=p->b; Q->front->next=p->next; if(Q->rear==p) Q->rear=Q->front; free(p); return OK; } Status QueueLength(LinkQueue Q) { int i=0; p=Q.front; while(Q.rear!=p) { i++; p=p->next; } return i; } Status QueueEmpty(LinkQueue Q) { if(Q.front==Q.rear) return TRUE; else return FALSE; } void main() { int i,m; char n,a[20]; InitStack(&S); InitQueue(&Q); gets(a); for(i=0; a[i]!='&'; i++) /////////// &前的數(shù)據(jù)進棧 { e.a=a[i]; Push(&S,e); } for(i=i+1; a[i]!='\0'; i++) ////////// ‘ &'后的數(shù)據(jù)進入隊列 EnQueue(&Q,a[i]); if( StackLength(S)!=QueueLength(Q)) /////棧和隊列的數(shù)據(jù)個數(shù)不一樣 printf("NO!!!!!!!!!!!!!!!!!!!!!!!!!!!!"); else while(!Stackempty(S)&&!QueueEmpty(Q))///////棧和隊列里還有數(shù)據(jù) { Pop(&S,&e); m=e.a; DeQueue(&Q,&f); n=f; if(m!=n) { printf("NO!!!!!!!!!!!!!!!!!!!!!!"); break; } } if(m==n&&Stackempty(S)&&QueueEmpty(Q)) printf("YES!!!!!!!!!!!!!!!!!!!!!!"); }
運行結(jié)果:
關于“如何用C語言棧和隊列實現(xiàn)回文檢測功能”這篇文章的內(nèi)容就介紹到這里,感謝各位的閱讀!相信大家對“如何用C語言棧和隊列實現(xiàn)回文檢測功能”知識都有一定的了解,大家如果還想學習更多知識,歡迎關注創(chuàng)新互聯(lián)行業(yè)資訊頻道。