欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C語言如何用順序棧實現(xiàn)回文序列判斷

 更新時間:2021年10月15日 16:00:51   作者:正在學(xué)c的小白  
這篇文章主要為大家介紹了C語言如何用順序棧來實現(xiàn)回文序列的判斷,文中含有詳細的代碼示例及分析,有需要的朋友可以借鑒參考下,希望能夠有所幫助

我是采用了兩個棧值得比較大小判斷得(可能比較浪費空間但是代碼我感覺簡單一點)

首先是定義一個棧的結(jié)構(gòu)元素,由于是字符串類型就直接定義一個char的數(shù)組就可以:.

typedef struct stack
{
    char data[MAX_SIZE];      //儲存字符串// 
    int top;                  //記錄棧頂// 
}SeqStack;

下來就是初始化,我這里是用的耿國華老師的方法就直接給一個top元素指向棧頂,傳入的指針地址:.

void Initstack(SeqStack *S)   //初始化棧,讓top指向棧頂// 
{
	S->top=-1;
}

下面就是創(chuàng)建順序棧了,元素只要沒滿就一直可以入住:

int Push(SeqStack *S,char x)  //壓棧,只要top小于MAX_SIZE-1就可以繼續(xù)入棧// 
{
	if(S->top<=MAX_SIZE-1)
	{
	S->top++;
	S->data[S->top]=x;
    }else{
    	return -1;;
	}
}

下面是核心函數(shù),操作實現(xiàn)回文序列的判斷,我注釋的比較清楚直接看就可以了:

void Pop(SeqStack *S)        //出棧操作,也是最主要的操作// 
{
	SeqStack *p;                       
	p=(SeqStack*)malloc(sizeof(SeqStack));  //建立一個新的空棧,由于是指針類型要分配動態(tài)地址//
	Initstack(p);                           //給新的棧進行初始化// 
	int i=S->top/2;                         //i用來分割兩個字符串,將第二個字符串賦給新的空棧// 
	int j=i-1;                              //j用來記錄除了@之外的其他字符數(shù)量大小// 
	while(S->top!=i)                        //開始對空棧進行賦值,對原來的棧開始清空(清空一般大小)// 
	{
		p->top++;
		p->data[p->top]=S->data[S->top];
		S->top--;
    }
    S->top=S->top-2;                        //讓原來的棧直接指向數(shù)字,跨過了字符@// 
    for(int k=0;k<i-1;k++)                  //循環(huán)次數(shù)由i-1決定,也就是出去@字符之后的其他需要比較的字符// 
    {
    	if(S->data[S->top]==p->data[p->top])  //由于棧的特點先進后出,所以新棧的存儲順序和去掉@字符之后的舊棧的存儲順序是一樣的,所以這里直接比較// 
    	{
    		j--;                             //j是定義需要比較字符的大小,只要兩個棧的元素ASCLL相等j就減一,如果全部相等j為0,該字符串就是互為回文序列// 
		}
		S->top--;                            //兩個top指針向下值// 
    	p->top--;
		if(j==0)                         //判斷// 
		{
			printf("兩個字符串互為回文序列!");
		}
	}
	if(j!=0)
	{
		printf("兩個字符串不互為回文序列!");
	}
	free(p);                       //free掉分配的空間// 
}

下面附上整個代碼:

#include<stdio.h>
#include<stdlib.h>
#define MAX_SIZE 100
typedef struct stack
{
    char data[MAX_SIZE];      //儲存字符串// 
    int top;                  //記錄棧頂// 
}SeqStack;
void Initstack(SeqStack *S)   //初始化棧,讓top指向棧頂// 
{
	S->top=-1;
}
int Push(SeqStack *S,char x)  //壓棧,只要top小于MAX_SIZE-1就可以繼續(xù)入棧// 
{
	if(S->top<=MAX_SIZE-1)
	{
	S->top++;
	S->data[S->top]=x;
    }else{
    	return -1;;
	}
}
void Pop(SeqStack *S)        //出棧操作,也是最主要的操作// 
{
	SeqStack *p;                       
	p=(SeqStack*)malloc(sizeof(SeqStack));  //建立一個新的空棧,由于是指針類型要分配動態(tài)地址//
	Initstack(p);                           //給新的棧進行初始化// 
	int i=S->top/2;                         //i用來分割兩個字符串,將第二個字符串賦給新的空棧// 
	int j=i-1;                              //j用來記錄除了@之外的其他字符數(shù)量大小// 
	while(S->top!=i)                        //開始對空棧進行賦值,對原來的棧開始清空(清空一般大小)// 
	{
		p->top++;
		p->data[p->top]=S->data[S->top];
		S->top--;
    }
    S->top=S->top-2;                        //讓原來的棧直接指向數(shù)字,跨過了字符@// 
    for(int k=0;k<i-1;k++)                  //循環(huán)次數(shù)由i-1決定,也就是出去@字符之后的其他需要比較的字符// 
    {
    	if(S->data[S->top]==p->data[p->top])  //由于棧的特點先進后出,所以新棧的存儲順序和去掉@字符之后的舊棧的存儲順序是一樣的,所以這里直接比較// 
    	{
    		j--;                             //j是定義需要比較字符的大小,只要兩個棧的元素ASCLL相等j就減一,如果全部相等j為0,該字符串就是互為回文序列// 
		}
		S->top--;                            //兩個top指針向下值// 
    	p->top--;
		if(j==0)                         //判斷// 
		{
			printf("兩個字符串互為回文序列!");
		}
	}
	if(j!=0)
	{
		printf("兩個字符串不互為回文序列!");
	}
	free(p);                       //free掉分配的空間// 
}
int main()
{
	SeqStack S;
	char x;
	int m=0;
	Initstack(&S);
	printf("請輸入第一串字符\n");
	while(m!=2)                            //因為只需要輸入兩個字符串的判斷,判斷條件為m!=2// 
	{
	    scanf("%c",&x);
	    if(x=='@')                           //輸入@后表明第一個字符串結(jié)束// 
	    {
	    	m++;
	        if(m==1)
	        {
	        	printf("請輸入第二串字符:\n");
	     	}
    	}
     	Push(&S,x);
    }
    Pop(&S);
	return 0;
}

下面加一個例子:

判斷3+1與1+3是否為回文序列

以上就是C語言如何用順序棧實現(xiàn)回文序列判斷的詳細內(nèi)容,更多關(guān)于C語言順序棧實現(xiàn)回文序列判斷的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • C語言深入講解語句與選擇結(jié)構(gòu)的使用

    C語言深入講解語句與選擇結(jié)構(gòu)的使用

    這篇文章主要為大家介紹了C語言的語句與選擇結(jié)構(gòu),有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-05-05
  • c++雙向鏈表操作示例(創(chuàng)建雙向鏈、雙向鏈表中查找數(shù)據(jù)、插入數(shù)據(jù)等)

    c++雙向鏈表操作示例(創(chuàng)建雙向鏈、雙向鏈表中查找數(shù)據(jù)、插入數(shù)據(jù)等)

    這篇文章主要介紹了c++雙向鏈表操作示例,包括創(chuàng)建雙向鏈、刪除雙向鏈表、雙向鏈表中查找數(shù)據(jù)、插入數(shù)據(jù)等,需要的朋友可以參考下
    2014-05-05
  • 一篇文章帶你了解C語言:入門基礎(chǔ)(2)

    一篇文章帶你了解C語言:入門基礎(chǔ)(2)

    這篇文章主要介紹了C語言入門之基礎(chǔ)知識詳解,文中有非常詳細的C語言使用教程及相關(guān)基礎(chǔ)知識,對正在學(xué)習(xí)c語言的小伙伴們有非常好的幫助,需要的朋友可以參考下
    2021-08-08
  • C語言與C++動態(tài)通訊錄超詳細實現(xiàn)流程

    C語言與C++動態(tài)通訊錄超詳細實現(xiàn)流程

    這篇文章主要為大家介紹了C語言與C++動態(tài)實現(xiàn)通訊錄,具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2022-05-05
  • C語言實現(xiàn)新生入學(xué)登記系統(tǒng)

    C語言實現(xiàn)新生入學(xué)登記系統(tǒng)

    這篇文章主要為大家詳細介紹了C語言實現(xiàn)新生入學(xué)登記系統(tǒng),文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-06-06
  • 詳解進程同步與互斥機制

    詳解進程同步與互斥機制

    進程同步是一個操作系統(tǒng)級別的概念,是在多道程序的環(huán)境下,存在著不同的制約關(guān)系,為了協(xié)調(diào)這種互相制約的關(guān)系,實現(xiàn)資源共享和進程協(xié)作,從而避免進程之間的沖突,引入了進程同步
    2021-06-06
  • C++線性時間的排序算法分析

    C++線性時間的排序算法分析

    這篇文章主要介紹了C++線性時間的排序算法分析,是非常經(jīng)典的非比較排序算法,對于C++程序員有很大的借鑒價值,需要的朋友可以參考下
    2014-08-08
  • c語言實現(xiàn)的帶通配符匹配算法

    c語言實現(xiàn)的帶通配符匹配算法

    這篇文章主要介紹了c語言實現(xiàn)的帶通配符匹配算法,需要的朋友可以參考下
    2015-03-03
  • C++異常處理入門(try和catch)

    C++異常處理入門(try和catch)

    C++ 提供了異常機制,讓我們能夠捕獲運行時錯誤,本文就詳細的介紹了C++異常處理入門,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-08-08
  • 插入排序算法之希爾排序+直接插入排序

    插入排序算法之希爾排序+直接插入排序

    這篇文章主要介紹了插入排序算法之希爾排序+直接插入排序的相關(guān)知識,本文通過實例圖文相結(jié)合給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-11-11

最新評論