亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

如何判斷回文?

如何判斷回文?

C++
我有沒有告訴你 2016-10-22 11:08:16
求大神幫忙,??假設稱正讀和反讀都相同的字符序列為”回文”,試寫一個算法判別讀入的一個以’@’為結束符的字符序列是否是“回文”。用c++編寫,跪求完整代碼
查看完整描述

1 回答

?
望遠

TA貢獻1017條經驗 獲得超1032個贊

#include<stdio.h>
#include<stdlib.h>
#define?MAX?50
typedef?char?ElemType;
typedef?struct?linknode
{
	ElemType?data;
	struct?linknode?*next;
}LiStack;
//初始化鏈棧
LiStack?InitStack(LiStack?*s)
{
	s=(LiStack?*)malloc(sizeof(LiStack));
	s->next=NULL;
	return?*s;
}
//出棧
ElemType?pop(LiStack?*s,ElemType?*e)
{
	LiStack?*p;
	if(s->next==NULL)
	{
		return?false;
	}
	p=s->next;
	*e=p->data;
	s->next=p->next;
	free(p);
	return?*e;
}
//入棧
void?push(LiStack?*s,ElemType?e)
{
	LiStack?*p=(LiStack?*)malloc(sizeof(LiStack));
	p->data=e;
	p->next=s->next;
	s->next=p;
}
//判斷是否是回文序列
bool?Match(LiStack?*l,char?str[],int?length)
{
	char?c;
	int?i;
	bool?flag=true;
	for(i=0;i<length;i++)
	{
		if(str[i]!=pop(l,&c))
		{
			flag=false;
			break;

		}

	}
	printf("\n");
	return?flag;

}
void?main()
{
	LiStack?l;
	int?i=0,length;
	char?str[MAX],c;
	l=InitStack(&l);
	printf("請輸入一行字符串以@結尾:\n");
	scanf("%c",&c);
	while(c!='@')
	{
		if(c!='\0'&&c!='\n')
		{
			str[i++]=c;
			push(&l,c);
		}
		scanf("%c",&c);
	
	}
	str[i]='\0';
	length=i/2;
	if(Match(&l,str,length))
	{
		printf("是回文序列!!\n");
	}
	else
	{
		printf("不是回文序列!!\n");
	}

}

運行結果:

http://img1.sycdn.imooc.com//580b0df80001c15f02740137.jpg

剛好實驗報告就是這個,不過是用c語言寫的,哈哈~~

查看完整回答
反對 回復 2016-10-22
  • 1 回答
  • 0 關注
  • 1745 瀏覽

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號