杨氏家谱树字是哪个辈的
杨姓谱牒修撰的历史相当悠久。汉代刘歆在《七略》中提到与他同时的杨雄有《家牒》,而一些古代地方志中摘引的《家牒》片断涉及杨雄身后世。《世说新语》刘孝标注提到数十种南朝士族家谱,其中有《杨氏谱》。《隋书经籍志·谱系类》录有:《杨氏血脉谱》2卷,《杨氏家谱状并墓记》1卷,《杨氏支分谱》1卷,《杨氏谱》1卷。此外,古籍中还提到北齐有佚名的《杨愔家传》。以杨姓和王姓等为多,南北朝时的杨姓大族,已有编撰家谱之风。
民国十二年(1923年)杨姓重新立宗续谱字辈:登、成、永、宏、福、生、考、义、和、平十字排辈为序。 近代杨贵德等在桐梓县娄山关镇虎峰山杨价崇德庙开会讨论百字谱: 弘农俊杰英、荣华泽祥祯、文武科举锦、福禄宁康兴、太师忠书令、唐宋才嘉兵、汉隋相尉权、崇德怀仁君、兰桂照辉映、侯州尽雄伟、盛海波涛涌、觉理冲凌云、启后继乾坤、慎思贵富民、树以成良言、勋著永绵传、严洁孝顺模、喜庆辅龙腾、昌发山西籍、源远承家业。 后修改为:三知承俊杰、荣华泽祥祯、汉隋相尉才、盛德怀仁君、文武科举锦、唐宋建奇勋、太师奉旨令、侯州忆雄英、沧海波涛涌、虎跃起龙腾、满门忠烈鼎、丰功壮凌云、慎思传清白、后裔靖康宁、兰桂照辉映、福禄显家声、昭著千秋范、源远伟业兴、廉洁行孝顺、继发晋乾坤。
诗礼彰庭训,家声周鲁培,洪昌谟自远,湘岳绪常恢,祖以初封显,系承可见来,本音原作善,忠厚启贤才。”
字辈排行
蚌埠固镇县湖沟镇单氏字辈:忠学钦玉(凤)桂 永乃祖训······ 湖南平江单氏南安堂字辈: 裕昆公房旧派:“士功年季干胜信宗德万志伏启嘉报说禹梦仲士功良文寇希天有拱玉庆惟士功九时宗文万福文升昭开本大用世楚希以为兴显达光明远攸隆福荫深衡应凤大世元文龙祖希邦永攸隆福荫深”; 峰仑两房旧派:“启嘉报说禹梦雄士功建立必昌隆壮志升霄汉玉友琢秀豪添仁仕显胜世代学归朝理道傅先圣心源继古贤”; 新派:“心树长荣茂楩楠国干桢动名纪青史诗礼振家声”。 湖南湘阴单氏字辈:“开本大用世楚希以为兴显达光明远攸隆福荫深”。
浙江萧山西河单氏仁孝堂字辈: 原派:“休嘉筑钧锡梦雄士功建立必昌隆”; 续派:“壮志升霄汉玉友琢秀豪添仁仕显胜世□学归朝”; 新派:“理道传先圣心源继古贤国家培植厚发达自珠聊”。 浙江湖州单氏字辈:“楚君涵克士朝林喜志明家学忠和厚功成育秀梁扬发前才美辉朗长兆延吉祥兴隆盛荣华富贵根”。 浙江温州单氏字辈:“华明君子道德良存荣祖亦可以正肇乾山世林忠光士文宗殿嘉永茂国定献金圣贤豪杰官员功勋”。 河南邓州单氏字辈:“仕福明清建振德丰化元兴仁世界昌”。 山东禹城单氏字辈:“树传兆吉玉”。
山东东明双井村单街单氏字辈:“大忠思琳克章美国文纲鸣世昭全德才宽惠泽长振家延富庶天道锡纯良广建志宏伟开进运吉祥”。 山东单县单氏字辈:“永怀继宗志 绍承衍世长 法正联同德 绪乃兆延祥 恩誉仰师敬 吉盛庆恒扬 千秋传孝义 和睦繁荣昌 开来鸿康泰 隆运生晓光 文武家振远 礼智化万方”。开始的“永”字辈是117世。 山东高密单氏:“祜传昭际亦既联葆体徯余人具旃胥今慕式心于兹弥睦与协勿自施原引普肖亘由而”。
山东滕州东洋汶村单氏字辈:“孝若群荣家 祥之兆庆远 贤绍宜永长” 江苏盐城南安堂单氏字辈: 马鹿垛祠堂十六世起字派:“楚君涵克士朝林喜志明家学忠和厚功成育秀深扬发前才美耀朗长兆延吉祥兴隆盛荣华富贵根”; 马鹿垛祠堂二十二世起字派:“守同保眉春长宝兆玉昌”; 马鹿垛祠堂二十三世起字派:“全福凤堂涌公”; 马鹿垛祠堂二十四世起字派:“恒永佩堂”; 马鹿垛祠堂二十五世起字派:“九如金山玉胜长年庆”; 马鹿垛祠堂二十六世起字派:“洪观国有中根成俊”; 马鹿垛祠堂二十七世起字派:“干根彬玉春忠彩爱建军喜绍正秋东龙圣小金秀大芹兰凤银杰巧霞慧成招爱阿玉翠林洪汉燕兄娟婷建忠飞玢景海留友莹彩莲娣艳晓书珍靓雷腊琴”。 吉林德惠单氏字辈:“有永文国成魁(奎)清(青)亚宇”。
安徽单氏一支字辈:“玉永言孝……” 贵州单氏一支字辈:“嘉升周鲁培……” 单氏一支字辈:“起克守宝”。 单氏一支字辈:“可洪尔言之普克大明学广有维士功勤茂思治佩”。 单氏一支字辈:“铭瀚楦肇云敦应分建文永月维谷开华恒元岳福”。 山东济南商河县单元村字辈:“文长传金祥天桂荣庆昌经济召梅林建凤世家梁”。
单氏一支字辈:“纪国正其礼兵新”。 湖南衡山单氏字辈:诗礼彰庭训,家声周鲁培,洪昌谟自远,湘岳绪常恢,祖以初封显,系承可见来,本音原作善,忠厚启贤才。 安徽定远单氏字辈:宏良学友廷,国正其新顺。
河南柘城以单桥为主迁居的字辈:从二十二世为:广修文德 传 继 恭 良 仁 义 礼 智 兴 国 其 昌 河南省邓州市刘集镇单坡村字辈:国进培魁金玉长洪天子贵宗政万书衡德明立奇功 同兴振家庭 江苏盐城响水单氏字辈:敬录前谱列序 秉体年以立 金峰本正东 春山怀秀士 德兆达朝中 续修列序 玉宇甲苏宁 华章冠连通 高洁显宏志 楚云耀江彤 江苏沭阳马厂镇大单庄村单氏字辈:久可义士 步振兆顺 永怀明爱 华喜得祥("爱华喜得祥"是村里长辈后续) 口市东莱街道单家村及邹家村是单姓的主要居住地,现居住人口大约两千多人。
现有排辈用字是:复丕基用汝承世德笃宗人福履宜常延。 山东省枣庄市薛城区周营镇单楼村(原山东峄县单家楼)单姓字辈:“邦芳楷润纯 文秉永茂成;立德绍先业 守世庆吉祥;孝宗重道恒,尧景兴纪长;志义传珍宝,舜化兆福强。
岳飞后裔统一字谱:
自二十二世起用:
重开奇秀,永佐朝邦;崇修(德)喜彩,忠(增、宗)耀远光;英贤辅弼,金玉其相;武穆家风,山高水长。
你有家谱的话,查一查你是第几世,延续下就行了。
本人也是忠武穆后裔,家里就有家谱。我们这一支是岳霆次子岳玙河南获嘉县后裔:
从二十五世起:
士在植步尔,绍学修希凤,会全思成忠,宪君北陶恢。本人凤字辈,是岳飞第三十四世孙。
各地都有不同的字谱,我给你搜集了一下,你看看自己能套用上那一套。
岳云长子岳甫湖南益阳后裔:
自十九世起:
时太灵山锤异最,青云志上佐朝廷。文章大启宏诗礼,敬作承先肇本宁。绪守虞衡常念祖,道宗孔孟重传经。安邦定国资家教,伟烈丰功耀鼎铭。
岳云长子岳甫山东临沂市后裔:
自三十世起:
忠孝国祯,仁义端祥,思承厚德,嗣绪永昌。
岳雷次子岳纬山东莘县观城后裔:
自二十三世起:
钟际林肇锡,新然有三振,国法九世清,训谟广垂统,继述善守成,嗣绪其永昌。
岳雷次子岳纬河南原阳县后裔:
自二十七世起:
良富廷远美(连),光生(继)王茂荣,和平传世广,积德显芳铭。
岳雷四子岳纪云南贵州后裔
从十三世岳俊青起:
俊桂锐宗乾,钟天山应连,忠勋铭玉鼎,朝廷保英贤,泰衡贻世泽,华蒿显万年,文武靖大国,礼义修徵传。鲁鄂根深固,西南茂荣繁,怀笑平安福,家兴祖德权。
岳雷四子岳纪贵州赫章县后裔:
自十五世起:
想宗辅钟,天祜应连,祥世振朝,都远绍克,佳智宏开,顺琼恒良。崇恩敬先,盈禄寿康,绪维豫汤,育衍云贵,恭俭承继,孝信守章。博学萃林,财隆盛旺,锦誉浩扬。
岳霖长子岳琮河南巩义市后裔:
从十八世起:
生景国进,三元承志,五德世稀,克绍祖法,光显玉玑。
岳霖长子岳琮洛阳寺里碑后裔:
从二十一世起:
崇钟惟生,文至德显,忠绳先启后,明道成义荣前耀昆。
岳霖次子岳琛山东桓台县后裔:
从二十二世开始:
毓德振宗,端本可大,维道乃兴,念祖先发,儒业传家,英俊华国。
岳霖三子岳珂河南平顶山后裔:
从二十八世起:
功德勋业广,荣庆福寿长,宗士恭忠雅,耀仁承志祥,远华锦茂润,贤彩秀繁昌。
岳霖三子岳珂江西南昌后裔:
从二十六世起:
崇修喜彩、忠耀远贤,开昌启运。
岳霖三子岳珂山东安丘北张洛后裔:
自三十世起:
维武乃言,广济世传。
岳霖三子岳珂江苏丰县后裔:
自二十二世始:
重开奇才,永佐朝邦。崇修喜彩,宗耀远贤。慎怀先志,恭俭世绵。树春久常,兴玉传广。彦兆龙继,金少敏昌。万代有绪,同起凤翔。建华景峻,东西明光。保法良成,文会宪章。
山东曲阜、泗水后裔
从二十六世始:
绪本西都衍, 东千顺大明
岳震三子岳玭四川南江流溪房、强家岭后裔:
从七世起:
之鼎文思绍,忠泰本一守。玖训春允魁,直(惠)儒岚腾川。宋廷中玉(毓) 秀,文光焕斗山。才华飞翰顶,荣臣登高攀。
岳震三子岳玭四川盐亭、蓬溪后裔:
从三十一世起:
定蕴崇辉兆,祥腾美庆安,显成荣锦世,嘉泽发奇元,泰德隆昌茂,阳刚耀自乾,常清守焕丕,广载久长全,舒怀开极盛,华采固维宣,肇继启光秉,文章应克传。
岳震四子岳琚湖南常德后裔:
从二十七世始:
昭右有序,载锡之光,诗书道远,仁孝泽长,宗功丕振,祖德克扬,天开宏运,万世永昌。
岳震四子岳琚湖南石门县后裔
从十六世起:
正子玉准兴,学善仕宏开,上升光万国,有志成忠怀,德业绍先祖,文章佐贤才,传家克大定,永昌庆方来,敬宋宜外振,显名在修培,敦厚可立本,纯儒应占魁。
岳震四子岳琚湖南衡东后裔、岳震四子岳琚贵州赫章白果镇后裔:
从十九派开始:
友元仲大正,尚良应永兴,文昌开万代,学士绍三登,成宪惟能继,芳规乃克绳,荣名光典策,祖德世相承。
岳震四子岳琚重庆綦江县三会后裔:
从二十三世起:
国朝兴正永,宗仕智明家。恩德承芳远,学相启人贤。万吉光廷秀,福禄寿长春。
岳霆长子岳璠湖南邵阳县后裔:
从十世起:
汝仲应元永、添志廷继文、伯大正光启、祖宗万世荣、有子经纶重、诒谋德泽新、守先延绪业、待后广修明。(根据《岳飞家史考》第七册100页和岳志勇《双清区岳飞后裔源流考记》改正)
岳霆长子岳璠安徽凤台岳张集支系:
从二十二世起:
正学传千古,人文粹一家,承先多世泽,继贤广良才。
岳霆长子岳璠安徽阜阳市后裔:
从三十世起:
崇德敬祖,福禄寿康,文显皖颍,忠衍豫汤,恭俭传世,孝信永芳,景行维端,善心循良。
岳霆次子岳玙河南遂平县马庄后裔:
从二十三世始:
蓝纲林辉全,清峰彬正文,春岭海连永,年高泽志富,祺成恒国荣。
岳霆次子岳玙河南获嘉县后裔:
从二十五世起:
士在植步尔,绍学修希凤,会全思成忠,宪君北陶恢。
岳霆次子岳玙天津宁河岳道口村后裔:
约从十七世起:
友洪真明守,秀自文可秉,九连和树广,锡士景国荣,云来庆大有,雨致喜年丰。
贵州绥阳岳氏
如国世正兴 明朝志大清
安邦元立德 美景万年春
洞庭贻谋远 江阳圣泽新
功勋昭宋殿 甘露兆天灵
河北滦县岳氏
庭余崇金成 春光绪祖先
富贵传文武 诗书纪世年
四川宜宾文兴县岳氏
可世再传后 仑钟朝上天
步登观奉启 承继向宏铮
安徽肥西县岳氏
国朝文学,甫世贤良,忠友余庆,孝本传芳
河南桐柏县岳氏
仁意力功进 万兴政清林文秀有家祥
山东威海雷系字谱
从33世开始
恭俭传世,仁孝泽长,建华景俊,文惠宪章;天开鸿运,继寿永昌,尽忠报国,万代安康。
写家谱族谱的方法如下:把知道的都写下来、采访家人、寻找实物线索、绘制家族树、制定研究计划等。
1 把知道的都写下来
关于家里,你记得什么,就都写下来,特别是出生、结婚、死亡的日期和地点,后者将在未来的实地调研中发挥重要作用。你或许还可以绘制简单的家族树。这将提醒你已经知道了什么,还想知道什么。
2 采访家人
现存的家族成员是知识的宝库。从父母以及他们的兄弟姐妹开始,然后如果可以,就再采访祖辈。如果祖辈还能记起他们的祖辈,那么你就有机会接触百年以上的家族历史了。在采访的时候,如果方便,你可以录音。
这份资料,既有利于你未来的调研,也可以作为遗产传至后人。但要记着贴上标签,以便寻找。要注意名字。还要记下别名、绰号,等等。一个故事,可能有不同的说法,要进行比较。要注意搜集“谣言”或者“模糊的回忆”。
3 寻找实物线索
翻翻抽屉和箱子,你可能会为自己的发现而感到惊奇。显而易见,诸如证书、表格之类的文件,可能会成为家族历史的砖石。这有可能了解到一段不为人所知的往事。
留意其他家族遗物,例如日记本、信函。照片也是非常重要的道具。跟亲戚聊聊,看看他们能否辨认照片上的人物。记下名字,扫描照片,贴上标签。最后,也是最重要的,打听一下家人、亲戚和族人,是否有家谱。
4 绘制家族树
家族树是描绘祖先关系的地图。它可能花费时间,所以要肯付出才能有结果。拿出一张白纸,在页底写下你自己的名字,在上面为先辈们留出空白。你也可以使用电脑。如果你是已婚,配偶列在你的旁边。然后在你们下面添加孩子,并填上出生日期。
上面是父母,再上面是祖辈,并且填上出生日期。你追溯的时候,直系祖辈的数量会翻倍——四位祖辈,八位曾祖辈,等等,加上他们的出生日期、结婚日期和死亡日期。
5 制定研究计划
记忆因时光变得模糊,所以验证非常重要。跟官方记录核对姓名和日期,常常都是不错的主意。现在可以查阅许多出生、结婚和死亡证书。你可以试着去本地档案馆、图书馆查询。
户籍档案也是查询数据或者未知亲戚的方式。民国时期的户籍资料,一般存放在档案馆里。另外,在地方志馆,也可以通过查阅地方志和文史资料,了解祖辈的生活环境和可能经历的大事,运气好的话,还可以找到他们的名字和事迹。
除了本地资源,网络资源、图书、杂志或者报纸,也可能提供实际的帮助。需要特别指出的是,图书馆里也收藏了大量的家谱和地方志。图书馆领导曾经讲过,有1/5的中国人其实是可以找到自己的家谱。
以word 2007为例,方法如下:
1、依次单击“插入”、插图框中的“SmartArt”,在出现的对话框中选择“层次结构”、在右边出现的“组织结构图”中选中竖排或横排的结构图例,双击出现的“文本”,填写家谱姓氏辈份等信息。
2、家族人丁兴旺的可以在不同的辈份(行或列)添加多个文本,具体方法是点击想要添加位置附近文本框,在菜单栏中点击“添加形状”,在子菜单中选择在后、前、上、下添加即可。
3、页面布局可以设置为横板,纸张设置大些,因为家谱人员太多,一张A3横板往往都写不下。
湖南耒阳吴氏家谱字辈排行表 :时英门千仲,仁义友思志,忠大朝正学,万国从(从)宗德,本荣(云)增钜(巨)济,树烈均镇湘,极熏基银汉,彩焕在锦江。我们都是(吴)千二郎的子弟,后面的字辈排行是按照“木”“火”“土”“金”“水”五行取的排行,希望我们吴氏家族发扬光大、子孙满堂。。。
我是耒阳市公平圩镇南禾村吴家湾吴俊腾,字辈排行“钜”。
C++语言: 二叉树实现的简单家谱树
/
File Name: BiTreecpp
Author: Geng Lequn[glq2000@126com]
Thur July 1 2010
Discription: 建立二叉家谱树,实现输入任意两个人的名字,查找得到其关系
/
#include <iostream>
#include <string>
#include <cstring>
#include <cstdlib>
#include <vector>
#include <mathh>
using namespace std;
typedef struct _Node
{
string sex; //性别 m 男; f 女
string name; //此人的姓名
string spause; //配偶的姓名
unsigned short level; //层次 辈分最高一层为1,下一层为为2,以此类推
struct _Node l_child; //指向其第一个孩子的指针
struct _Node r_brother; //指向其某一个兄弟姐妹的指针, 即左孩子为其后代,右孩子为其兄弟姐妹
struct _Node btr; //指向其父亲或者母亲的指针
_Node():level(0),l_child(NULL),r_brother(NULL),btr(NULL){cout<<"constructor"<<endl;}
~_Node(){cout<<name<<" destructor"<<endl;}
}Node, PNode;
void CreateBiTreePreOrder(PNode &pn, PNode pback, unsigned short depth);//建立二叉家谱树,以先序方式
void VisitBiTreePreOrder(PNode root); //前序遍历此二叉树
void TellRelation(PNode root); //判断两人关系
void DestroyBiTreePostOrder(PNode root); //销毁二叉树,释放节点占用的空间
void FindPersonMiddleOrder(PNode root, string name, PNode &presult); //返回家谱中指向某人的指针,找不到返回NULL
Node root=NULL; //全局变量,二叉树的根节点
unsigned findPersonFlag = 0; //标志位,0 没找到; 1 找到,找到后就不再搜索直接返回;利用此flag可避免将整个tree遍历一遍(若该name在tree中存在的话)
int main()
{
cout<<"请按先序遍历的顺序根据提示输入家谱信息,不存在则输入\"#\""<<endl;
CreateBiTreePreOrder(root, NULL, 1);//建立二叉家谱树,以先序方式
VisitBiTreePreOrder(root); //前序遍历此二叉树
TellRelation(root); //判断两人关系
DestroyBiTreePostOrder(root); //销毁二叉树
getchar();getchar();getchar();
return 0;
}
/
function:建立二叉家谱树,以先序方式
argument:
pn: 指向二叉树节点的引用
pback: pn这个节点的btr指针的值,即指向其parent的指针
depth: 该节点的层次,分最高一层为1,下一层为为2,以此类推
/
void CreateBiTreePreOrder(PNode &pn, PNode pback, unsigned short depth)
{
string str;
cin>>str; //输入该人信息,格式是 sex-name-spausename,如不存在则输入#
if(str == "#") //如: M-tom-marry, 表示此人叫tom, 男性, 配偶名字marry
{
pn = NULL;
return;
}
//如果是自定义的struct/class,应该使用构造函数。如果是内建数据类型,
//比如int,应该memset。 当然,更好的建议是使用vector取代new出来的数组
pn = new Node;
//处理输入的字符串
vector<string> v;
for(size_t b=0, e=strfind('-'); ; e=strfind('-', b))
{
if(e == string::npos)
{
vpush_back(strsubstr(b));
break;
}
else
vpush_back(strsubstr(b, e-b));
b = e+1;
}
//初始化该节点
pn->sex = v[0];
pn->name = v[1];
pn->spause = v[2];
pn->btr = pback;
pn->level = depth;
//递归建立左右子树的节点
CreateBiTreePreOrder(pn->l_child, pn, depth+1); //注意后两个参数的值
CreateBiTreePreOrder(pn->r_brother, pback, depth); //注意后两个参数的值
}
/
function: 前序遍历此二叉树
/
void VisitBiTreePreOrder(PNode pn)
{
if(!pn)
return;
cout<<endl<<"sex:"<<pn->sex<<endl;
cout<<"name:"<<pn->name<<endl;
cout<<"spause:"<<pn->spause<<endl;
cout<<"level:"<<pn->level<<endl;
cout<<"father's name:"<<((pn->btr == NULL)"NULL":pn->btr->name)<<endl;
cout<<"======================"<<endl;
VisitBiTreePreOrder(pn->l_child);
VisitBiTreePreOrder(pn->r_brother);
}
/
function: 中序遍历找到家谱中的一个人,返回其指针,若找不到,返回NULL
isSpause 1表示是找到的节点的配偶 0表示不是所找到的节点的配偶
/
void FindPersonMiddleOrder(PNode pn, string name, PNode &presult)
{
if(!pn)
return;
FindPersonMiddleOrder(pn->l_child, name, presult);
if(findPersonFlag) return;
if(name == pn->name || name == pn->spause)
{
presult = pn;
findPersonFlag = 1; //全局标志位,0 没找到; 1 找到,找到后就不再搜索直接返回;利用此全局flag可避免将整个tree遍历一遍(若该name在tree中存在的话)
return; //下次使用前不要忘记置为0
}
FindPersonMiddleOrder(pn->r_brother, name, presult);
}
/
function: 判断两人关系,若两人中至少一人不在树中,则两人无关系
若两人在树中,先判断两人是否同层次,若同层,判断是否是亲兄弟姐妹;
若不同层,设辈分大的人为A,辈分小的人为B,判断A和B是亲的还是表的,
比如,A为男性,且比B大一倍,判断A是否为B的爸爸,或亲叔叔(舅舅),或表叔叔(舅舅)
简单起见,此处没有区分是叔叔还是舅舅
比如,A为男性,且比B大两倍,判断A是否为B的亲爷爷(姥爷),或亲爷爷(姥爷)的亲兄弟
,或亲爷爷(姥爷)的表兄弟
简单起见,此处没有区分是叔叔和舅舅等做进一步区分
简单起见,查询时只输入节点中的name,不查询spause,否则处理起来太麻烦
/
void TellRelation(PNode pn)
{
string name1, name2;
//p1指向name1, p2指向name2, pbig指向辈分大的,psmall指向辈分小的
PNode p1 = NULL, p2 = NULL, pbig = NULL, psmall = NULL;
int differ = 0; //两人辈分数的差别
string title;
Label:
cout<<endl<<"输入想查询关系的两个人的名字,不想查则将两人名字输成#:"<<endl;
while(cin>>name1 && cin>>name2)
{
if(name1=="#" && name2=="#") return;
p1 = NULL; p2 = NULL; //因为程序是循环执行的,需要将上次遗留的值清掉
findPersonFlag = 0;
FindPersonMiddleOrder(root, name1, p1);
findPersonFlag = 0;
FindPersonMiddleOrder(root, name2, p2);
if(!p1 || !p2) //若有一个为空或都为空,说明至少有一个人不在家谱中,故两人无亲缘关系
{
cout<<name1<<((!p1)" 不在":" 在")<<" 家谱树中"<<endl;
cout<<name2<<((!p2)" 不在":" 在")<<" 家谱树中"<<endl;
cout<<name1<<" 和 "<<name2<<" 间没有关系"<<endl<<endl;
goto Label;
}
differ = (int)abs(p1->level - p2->level);
if(!differ) //辈分一样大
{
if(p1->sex == p2->sex)
{
if(p1->sex == "M") title = "兄弟关系";
else title = "姐妹关系";
}
else title = "兄妹(姐弟)关系";
if(p1->btr == p2->btr) //parent相同
cout<<name1<<" 和 "<<name2<<" 间是 "<<" 亲 "<<title<<endl;
else
cout<<name1<<" 和 "<<name2<<" 间是 "<<" 表 "<<title<<endl;
}
else //辈分不一样大
{
if(p1->level < p2->level) {pbig = p1; psmall = p2;}
else {pbig = p2; psmall = p1;}
switch(differ)
{
case 1:
if(psmall->btr == pbig)
title = ((pbig->sex == "M")"爸爸":"妈妈");
else
{
if(psmall->btr->btr == pbig->btr)
title = ((pbig->sex == "M")"亲叔(舅)":"亲姑(姨)");
else
title = ((pbig->sex == "M")"表叔(舅)":"表姑(姨)");
}
break;
case 2:
if(psmall->btr->btr == pbig)
title = ((pbig->sex == "M")"爷爷(姥爷)":"奶奶(姥姥)");
else
{
string tmp = ((pbig->sex == "M")"兄弟":"姐妹");
if(psmall->btr->btr->btr == pbig->btr)
title = ((psmall->btr->btr->sex == "M")"爷爷(姥爷)的亲":"奶奶(姥姥)的亲") + tmp;
else
title = ((psmall->btr->btr->sex == "M")"爷爷(姥爷)的表":"奶奶(姥姥)的表") + tmp;
}
break;
default:
string tmp2;
PNode pt = psmall;
int n = differ-2; //计算"老"字 (即grand这个字) 出现的个数
for(int i=0; i<n; ++i)
tmp2 += "老";
for(int i=0; i<differ; ++i)
pt = pt->btr;
if(pt == pbig)
title = tmp2 + ((pbig->sex == "M")"爷爷(姥爷)":"奶奶(姥姥)");
else
{
string tmp3 = ((pbig->sex == "M")"兄弟":"姐妹");
if(pt->btr == pbig->btr)
{title = tmp2 + ((pt->sex == "M")"爷爷(姥爷)的亲":"奶奶(姥姥)的亲"); title+=tmp3;}
else
{title = tmp2 + ((pt->sex == "M")"爷爷(姥爷)的表":"奶奶(姥姥)的表"); title+=tmp3;}
}
break;
}
cout<<pbig->name<<" 是 "<<psmall->name<<" 的 "<<title<<endl;
}
goto Label;
}
}
/
function: 后序遍历销毁此二叉树,释放节点占用的内存空间
/
void DestroyBiTreePostOrder(PNode pn)
{
if(!pn) return;
DestroyBiTreePostOrder(pn->l_child);
DestroyBiTreePostOrder(pn->r_brother);
delete pn;
}
杨氏家谱树字是哪个辈的
本文2023-10-21 10:09:35发表“资讯”栏目。
本文链接:https://www.lezaizhuan.com/article/306306.html