2018-05-13

//
//  Solution.cpp
//  LPCPlusPlusProject
//
//  Created by 鹏 刘 on 2018/3/21.
//  Copyright © 2018年 鹏 刘. All rights reserved.
//

#include "Solution.hpp"

//迭代求链表逆序
void Solution:: reverseList(ListNode *head) {
    ListNode *pre = NULL;
    ListNode *current = head;
    ListNode *next = NULL;
    while (current != NULL) {
        next = current -> next;
        current -> next = pre;
        pre = current;
        current = next;
    }

    head = pre;
}

//递归求链表逆序
void Solution:: recursiveReverseList(ListNode *head) {
    if (head -> next == NULL) {
        return;
    }

    ListNode *next = head -> next;
    recursiveReverseList(next);

    head -> next -> next = head;
    head -> next = NULL;
}

//递归求阶乘
int Solution:: recursiveFactorial(int n) {
    if (n == 0||n == 1) {
        return 1;
    } else {
        return n*recursiveFactorial(n-1);
    }
}

//非递归求阶乘
int Solution:: noRecursiveFactorial(int n) {
    int result = 1;
    for (int i = 1; i <= n; i ++) {
        result = result*i;
    }

    return result;
}

//上下左右递增二维数组求某数是否存在
bool Solution:: Find(int target, vector<vector<int> > array) {
    long int Row = array.size();
    long int Col = array[0].size();

    for (long int i = 0, j = Col - 1; i < Row && j >= 0;) {
        if (array[i][j] > target) {
            j--;
        } else if (array[i][j] == target) {
            return true;
        } else {
            i++;
        }
    }

    return false;
}

//请实现一个函数,将一个字符串中的空格替换成“%20”。例如,当字符串为We Are Happy.则经过替换之后的字符串为We%20Are%20Happy。
void Solution:: replaceSpace(char *str) {
    long int lenth = strlen(str);
    int count = 0;
    for (long int i = 0; i < lenth; i++) {
        if (str[i] == ' ') {
            count++;
        }
    }

    for (long int i = lenth - 1; i >= 0; i--) {
        if (str[i] != ' ') {
            str[i+2*count] = str[i];
        } else {
            count--;
            str[i+2*count] = '%';
            str[i+2*count+1] = '2';
            str[i+2*count+2] = '0';
        }
    }

    printf("现在的str is %s\n",str);
}

//快速排序
void Solution:: fastSort(int *arr,int left,int right) {
    int i = left; int j = right;

    if (left > right) {
        return;
    }

    int key = arr[left];

    while (i != j) {
        while (arr[j] >= key && j > i) {
            j--;
        }

        while (arr[i] <= key && j > i) {
            i++;
        }

        //找到左边大于基准数的跟右边小于基准数的交换位置
        if (j > i) {
            int temp = arr[i];
            arr[i] = arr[j];
            arr[j] = temp;
        }
//        printf("快排后");
//        for (int i = 0; i < 7; i++) {
//            printf("%i,",arr[i]);
//        }
//        printf("\n");
    }
    //交换基准数
    arr[left] = arr[i];
    arr[i] = key;

//    printf("快排后");
//    for (int i = 0; i < 7; i++) {
//        printf("%i,",arr[i]);
//    }
//    printf("\n");

    fastSort(arr, left, i-1);
    fastSort(arr, i+1, right);
}

//非递归斐波那契数列求第n位数值
int Solution:: fibonacci(int n) {
    int result = 0;
    int a = 1;
    int b = 1;

    if (n == 0||n == 1) {
        result = a;
        return result;
    }

    for (int i = 2; i <= n; i++) {
        result = a + b;
        a = b;
        b = result;
    }

    return result;
}

//递归斐波那契数列求第n位数值
int Solution:: recursiveFibonacci(int n) {
    if (n == 0||n == 1) {
        return 1;
    }

    return recursiveFibonacci(n - 1) + recursiveFibonacci(n - 2);
}

//递归求解杨辉三角
int Solution:: recursiveTriangle(int i,int j) {
    if (j == 0 || i == j) {
        return 1;
    }

    return recursiveTriangle(i - 1, j - 1) + recursiveTriangle(i - 1, j);
}

/*
              9
           /     \
          4       8
        /       /   \
       3       6     7
     /   \      \
    2     1      5
 */
/**
 * 前序遍历【根左右】根在最前
 * 中序遍历【左根右】根在中间
 * 后续遍历【左右根】根在最后
*/
void Solution:: initTree() {
    TreeNode H = TreeNode(1);
    TreeNode G = TreeNode(2);
    TreeNode D = TreeNode(3);
    D.left = &G;
    D.right = &H;
    TreeNode B = TreeNode(4);
    B.left = &D;
    TreeNode I = TreeNode(5);
    TreeNode E = TreeNode(6);
    E.right = &I;
    TreeNode F = TreeNode(7);
    TreeNode C = TreeNode(8);
    C.left = &E;
    C.right = &F;
    TreeNode A = TreeNode(9);
    A.left = &B;
    A.right = &C;

    this->PrintPreOrder(&A);

    printf("二叉树前序遍历(递归):");
    this->PrintPreOrderReverse(&A);
    printf("\n");

    this->PrintInOrder(&A);

    printf("二叉树中序遍历(递归):");
    this->PrintInOrderReverse(&A);
    printf("\n");

//    this->PrintPostOrder(&A);

    printf("二叉树后序遍历(递归):");
    this->PrintPostOrderReverse(&A);
    printf("\n");

    this->PrintFromTopToBottom(&A);

    this->PrintFromBottomToTop(&A);
}

void Solution:: PrintPreOrder(TreeNode *root) {
    printf("二叉树前序遍历(非递归):");

    stack<TreeNode*> s;
    TreeNode *t = root;
    s.push(t);
    while (!s.empty()) {
        t = s.top();
        if (t) {
            printf("%i ",t -> val);
            s.pop();
            if (t -> right) {
                s.push(t -> right);
            }

            if (t -> left) {
                s.push(t -> left);
            }
        }
    }

    printf("\n");
}

void Solution:: PrintPreOrderReverse(TreeNode *root) {

    if (root) {
        printf("%i ",root -> val);
        PrintPreOrderReverse(root -> left);
        PrintPreOrderReverse(root -> right);
    }
}

void Solution:: PrintInOrder(TreeNode *root) {//
    printf("二叉树中序遍历(非递归):");

    stack<TreeNode*> s;
    TreeNode *t = root;
    while (t != NULL || !s.empty()) {

        while(t != NULL) {
            s.push(t);
            t = t->left;
        }

        if(!s.empty()) {
            t = s.top();
            printf("%i ",t -> val);
            s.pop();
            t = t->right;
        }
    }

    printf("\n");
}

void Solution:: PrintInOrderReverse(TreeNode *root) {
    if (root) {
        PrintInOrderReverse(root -> left);
        printf("%i ",root -> val);
        PrintInOrderReverse(root -> right);
    }
}

void Solution:: PrintPostOrder(TreeNode *root) {
    printf("二叉树后序遍历(非递归):");

    stack<TreeNode*> s;
    TreeNode *t = root;
    TreeNode *r = NULL;

    while (t != NULL || !s.empty()) {

        while(t != NULL) {
            s.push(t);
            t = t->left;
        }

        if (!s.empty()) {
            t = s.top();
            if (t -> right&&t -> right != r) {
                t = t -> right;
            } else {
                t = s.top();
                printf("%i ",t -> val);
                r = t;
                s.pop();
            }
        }
    }

    printf("\n");
}

void Solution:: PrintPostOrderReverse(TreeNode *root) {
    if (root) {
        PrintPostOrderReverse(root -> left);
        PrintPostOrderReverse(root -> right);
        printf("%i ",root -> val);
    }
}


vector <int> Solution:: PrintFromTopToBottom(TreeNode *root) {
    printf("二叉树从上到下 从左往右(非递归):");

    queue <TreeNode*> q;
    q.push(root);
    vector <int> r;
    while(!q.empty()){
        root = q.front(); q.pop();
        if(!root) continue;
        r.push_back(root -> val);
        printf("%i ",root -> val);
        q.push(root -> left);
        q.push(root -> right);
    }
    printf("\n");

    return r;
}

vector <int> Solution:: PrintFromBottomToTop(TreeNode *root) {
    printf("二叉树从下到上 从右往左(非递归):");

    queue <TreeNode*> q;
    q.push(root);
    stack <TreeNode*> s;
    vector <int> r;
    while(!q.empty()){
        root = q.front(); q.pop();
        if(!root) continue;
        s.push(root);
        q.push(root -> left);
        q.push(root -> right);
    }

    while (!s.empty()) {
        TreeNode *node = s.top();
        r.push_back(node -> val);
        printf("%i ",node -> val);
        s.pop();
    }
    printf("\n");

    return r;
}

void Solution:: PringDiamond() {
    printf("/\\\n\\/\n");
}


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

推荐阅读更多精彩内容

  • 有这样一份执职业,要干很多体力活,要有耐心还要有责任心,要懂得金融,烹饪,医疗还要具备教育与和人际关系交往的能力,...
    Purplegrape琳阅读 305评论 0 0
  • (稻盛哲学学习会)打卡第65天 姓名:孔丽春 部门:CR 组别:反省二组 【知~学习】 诵读《活法》第五章 与其追...
    KellyWellin阅读 1,317评论 0 0
  • 如果不能成为别人生命中的礼物,那就不要走进别人的生活
    远方F阅读 108评论 0 0
  • 这个秋天,没有太多眷恋,没有太多忧愁,有的只是那份初识你时的激动,青春的懵懂,让我的心不断的跳动,那双粉色的...
    果果xqc阅读 103评论 0 0
  • 第18章回顾 伽罗大陆是一个巨大的岛屿,这里曾经是神族、龙族、人族与魔族的乐园,但自从魔族的野心日益扩大想要铲除其...
    陈瀛Neptune阅读 522评论 0 4