剑指offer第五天

面试题16 反转链表

思路 当我们调整节点i的next指针时,需要知道i的前一个节点,当i的next指向前一节点时,我们就无法找到i的下一个节点,所以我们还需要保存i的下一个节点。
代码

struct node * reverseList(struct node *head){
  struct node *p,*pre,*next,*reverseHead = NULL;
  pre=NULL;
  p=head;
  //如果链表只有一个节点 直接返回
  if (p->next==NULL) {
    return p;
  }

  while (p!=NULL) {
    next=p->next;
    //如果p是尾节点 那么p就是反转过后的头节点
    if (next==NULL) {
        reverseHead=p;
    }
    p->next=pre;
    pre=p;
    p=next;
}
return reverseHead;
}

递归代码

//递归反转链表
void DiguireverseList(struct node *pre,struct node *p,struct node *next){
    next=p->next;
//如果下一个节点为空 那么尾节点指向前一个节点 并且设置反转过后的头节点为p
    if (next==NULL) {
        p->next=pre;
        DiguireverseHead=p;
        //否则 p指向前一个节点 并移动pre,p递归调用函数
    }else{
        p->next=pre;
        pre=p;
        p=next;
        DiguireverseList(pre, p, next);
    }
   }

面试题17 合并两个排序的链表

输入两个递增的链表,合并两个链表使其仍然递增。
思路 比较两个链表的头节点,较小的加入新链表。下一步和上一步相同,递归完成这个过程。
代码

#pragma mark-合并两个递增链表
struct node * merge(struct node *p1,struct node *p2){
if (p1==NULL) {
    return p2;
}
if (p2==NULL) {
    return p1;
}
struct node *mergeNode=NULL;
if (p1->data<p2->data) {
    mergeNode=p1;
    mergeNode->next=merge(p1->next, p2);
}else{
    mergeNode=p2;
    mergeNode->next=merge(p1, p2->next);
}
return mergeNode;
}

面试题18 树的子结构

输入两颗二叉树a和b 判断b是不是a的子结构
思路 首先,遍历a 看a中有没有节点和b的根节点值相等,若有,遍历b看和a是否相同,直到b遍历完
代码

int DoseTree1hasTree2(struct BinaryTreeNode *p1,struct BinaryTreeNode *p2){
if (p2==NULL) {
    return 1;
}
if (p1==NULL) {
    return 0;
}
if (p1->value!=p2->value) {
    return 0;
}
return DoseTree1hasTree2(p1->leftchild, p2->leftchild)&&DoseTree1hasTree2(p1->rightchild, p2->rightchild);
}
int isSubtree(struct BinaryTreeNode *p1,struct BinaryTreeNode *p2){
int result=0;
//首先判断a树中有没有b树的根节点
if (p1 != NULL && p2 != NULL) {
    if (p1->value==p2->value) {
        result=DoseTree1hasTree2(p1, p2);
    }
    //向左子树找
    if (!result) {
        result=isSubtree(p1->leftchild, p2);
    }
     //向右子树找
    if (!result) {
        result=isSubtree(p1->rightchild, p2);
    }

}
return result;
}

面试题19 二叉树的镜像

思路 遍历二叉树,每到一个节点,若他是叶子节点,结束.若不是,交换他的左右节点。
代码

void mirror(struct BinaryTreeNode *p){
if (p->leftchild==NULL && p->rightchild==NULL) {
    return;
}
struct BinaryTreeNode *t=p->leftchild;
p->leftchild=p->rightchild;
p->rightchild=t;
if (p->leftchild) {
    mirror(p->leftchild);
}
if (p->rightchild) {
    mirror(p->rightchild);
}
}

面试题20 顺时针打印矩阵

按从里向外以顺时针的顺序依次打印出每一个数字。
将问题分解为两个问题 打印几圈 每一圈如何打印
代码

//打印一圈
void printCircle(int **numbers,int col,int row,int start){
int endx=col-1-start;
int endy=row-1-start;
int i=0;
//从左向右打
for (i=start; i<=endx; i++) {
    printf("%d",numbers[start][i]);
}
//从上往下打 endy要大于start
if (start<endy) {
    for (i=start+1; i<=endy; i++) {
        printf("%d",numbers[i][endx]);
    }
  }
//从右往左打 至少两行两列
if (start<endy&&start<endx) {
    for (i=endx-1; i>=start; i--) {
        printf("%d",numbers[endy][i]);
    }
}
//从下往上打 至少两行三列
if (start<endy-1&&start<endx) {
    for (i=endy-1; i>=start+1; i--) {
        printf("%d",numbers[i][start]);
    }
}
}
void Printclock(int **numbers,int col,int row){
int start=0;
while (col>start*2&&row>start*2) {
    printCircle(numbers,col,row,start);
    ++start;
}
}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,456评论 5 477
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,370评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,337评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,583评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,596评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,572评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,936评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,595评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,850评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,601评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,685评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,371评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,951评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,934评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,167评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 43,636评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,411评论 2 342

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 171,394评论 25 707
  • 总结 想清楚再编码 分析方法:举例子、画图 第1节:画图分析方法 对于二叉树、二维数组、链表等问题,都可以采用画图...
    M_巴拉巴拉阅读 1,203评论 0 7
  • 1.把二元查找树转变成排序的双向链表 题目: 输入一棵二元查找树,将该二元查找树转换成一个排序的双向链表。 要求不...
    曲终人散Li阅读 3,287评论 0 19
  • 楼下新开了家饺子馆。因为太过僻静,几乎无人问津。 那天懒得做饭,随丈夫到了饺子馆。老板娘满脸喜气招呼我们坐下。 店...
    安睡阅读 4,630评论 45 98
  • 都市的吃货就是一群悲观的动物, 尽管他们创造无数的伟大的物质文明,也创造令人瞩目的精神文明。 但他们整体还是悲伤的...
    Jum阅读 253评论 0 0