当前位置:  互联网>综合
本页文章导读:
    ▪Subsets II      题目: Given a collection of integers that might contain duplicates, S, return all possible subsets. Note: Elements in a subset must be in non-descending order.The solution set must not contain duplicate subsets. For example, If S = [1,2,2], a so.........
    ▪Reverse Linked List II      题目: Reverse a linked list from position m to n. Do it in-place and in one-pass. For example: Given 1->2->3->4->5->NULL, m = 2 and n = 4, return 1->4->3->2->5->NULL. Note: Given m, n satisfy the following condition: .........
    ▪Binary Tree Inorder Traversal      题目: Given a binary tree, return the inorder traversal of its nodes' values. For example: Given binary tree {1,#,2,3}, 1 \ 2 / 3 return [1,3,2]. 代码如下:     void getresult(TreeNode *root,vector<int&.........

[1]Subsets II
    来源: 互联网  发布时间: 2013-10-24

题目:

Given a collection of integers that might contain duplicates, S, return all possible subsets.

Note:

  • Elements in a subset must be in non-descending order.
  • The solution set must not contain duplicate subsets.

For example,
If S = [1,2,2], a solution is:

[
  [2],
  [1],
  [1,2,2],
  [2,2],
  [1,2],
  []
]

代码如下:

   void getsubset(set<vector<int> > &subsets,vector<int> &S,int i)
    {
        vector<int> tmp;
        for(int j=0;j<S.size();j++)
        {
            if(i&(1<<j))tmp.push_back(S[j]);
        }
        subsets.insert(tmp);
    }
    vector<vector<int> > subsetsWithDup(vector<int> &S) {
        set<vector<int> > subsets;
        set<vector<int> >::iterator j;
        vector<vector<int> > result;
        sort(S.begin(),S.end());
        int n=S.size();
        for(int i=0;i<1<<n;i++)
        {
            getsubset(subsets,S,i);
        }
        for(j=subsets.begin();j!=subsets.end();j++)
        {
            result.push_back(*j);
        }
        return result;
    }

作者:chunxia75qin 发表于2013-5-29 16:57:53 原文链接
阅读:80 评论:0 查看评论

    
[2]Reverse Linked List II
    来源: 互联网  发布时间: 2013-10-24

题目:

Reverse a linked list from position m to n. Do it in-place and in one-pass.

For example:
Given 1->2->3->4->5->NULL, m = 2 and n = 4,

return 1->4->3->2->5->NULL.

Note:
Given m, n satisfy the following condition:
1 < = m < = n < = length of list.

代码如下:

ListNode *reverseBetween(ListNode *head, int m, int n) {
        if(m==n)return head;
        int i=1;
        if(m==1)
        {
            ListNode *head1=head;
            while(i<n)
            {
                ListNode *tmp=head1->next;
                head1->next=tmp->next;
                tmp->next=head;
                head=tmp;
                i++;
            }
        }
        else
        {
            ListNode *head1=head;
            while(i<m-1)
            {
                head1=head1->next;
                i++;
            }
            ListNode *head2=head1->next;
            while(i<n-1)
            {
                ListNode *tmp=head2->next;
                head2->next=tmp->next;
                tmp->next=head1->next;
                head1->next=tmp;
                i++;
            }
        }
        return head;
    }

作者:chunxia75qin 发表于2013-5-30 12:58:47 原文链接
阅读:1 评论:0 查看评论

    
[3]Binary Tree Inorder Traversal
    来源: 互联网  发布时间: 2013-10-24

题目:

Given a binary tree, return the inorder traversal of its nodes' values.

For example:
Given binary tree {1,#,2,3},

   1
    \
     2
    /
   3

return [1,3,2].


代码如下:

    void getresult(TreeNode *root,vector<int> &result)
    {
        if(root==NULL)return;
        if(root->left!=NULL)
        {
            getresult(root->left,result);
        }
        result.push_back(root->val);
        if(root->right!=NULL)
        {
            getresult(root->right,result);
        }
        return;
    }
    vector<int> inorderTraversal(TreeNode *root) {
        vector<int> result;
        getresult(root,result);
        return result;     
    }

作者:chunxia75qin 发表于2013-5-30 12:49:27 原文链接
阅读:25 评论:0 查看评论

    
最新技术文章:
建站其它 iis7站长之家
▪背包 代码    ▪json对象的封装与解析    ▪01背包,完全背包,多重背包 ,模板代码
▪apache安装详解    ▪HDU 4668 Finding string (解析字符串 + KMP)    ▪《TCP-IP详解 卷1:协议》学习笔记(二)
▪《TCP-IP详解 卷1:协议》学习笔记(持续更新...    ▪windows下使用swig    ▪gensim试用
▪Linux Shell脚本编程--nc命令使用详解    ▪solr对跨服务器表联合查询的配置    ▪递归和非递归实现链表反转
▪Linux磁盘及文件系统管理 1---- 磁盘基本概念    ▪Cholesky Decomposition    ▪HTTP协议学习
▪用C语言写CGI入门教程    ▪用hdfs存储海量的视频数据的设计思路    ▪java多线程下载的实现示例
▪【原创】eAccelerator 一个锁bug问题跟踪    ▪hadoop学习之ZooKeeper    ▪使用cuzysdk web API 实现购物导航类网站
▪二维数组中的最长递减子序列    ▪内嵌W5100的网络模块WIZ812MJ--数据手册    ▪xss 跨站脚本攻击
▪RobotFramework+Selenium2环境搭建与入门实例    ▪什么是API    ▪用PersonalRank实现基于图的推荐算法
▪Logtype    ▪关于端口号你知道多少!    ▪Linux基本操作 1-----命令行BASH的基本操作
▪CI8.7--硬币组合问题    ▪Ruby on Rails 学习(五)    ▪如何使用W5300实现ADSL连接(二)
▪不允许启动新事务,因为有其他线程正在该会...    ▪getting start with storm 翻译 第六章 part-3    ▪递归求排列和组合(无重复和有重复)
▪工具类之二:RegexpUtils    ▪Coding Interview 8.2    ▪Coding Interview 8.5
▪素因子分解 Prime factorization    ▪C# DllImport的用法    ▪图的相关算法
▪Softmax算法:逻辑回归的扩展    ▪最小生成树---Kruskal算法---挑战程序设计竞赛...    ▪J2EE struts2 登录验证
▪任意两点间的最短路径---floyd_warshall算法    ▪Sqoop实现关系型数据库到hive的数据传输    ▪FFMPEG采集摄像头数据并切片为iPhone的HTTP Stream...
▪Ubuntu 13.04 – Install Jetty 9    ▪TCP/IP笔记之多播与广播    ▪keytool+tomcat配置HTTPS双向证书认证
▪安装phantomjs    ▪Page Redirect Speed Test    ▪windows media player 中播放pls的方法
▪sre_constants.error: unbalanced parenthesis    ▪http headers    ▪Google MapReduce中文版
▪The TCP three-way handshake (connect)/four wave (closed)    ▪网站反爬虫    ▪Log4j实现对Java日志的配置全攻略
▪Bit Map解析    ▪Notepad 快捷键 大全    ▪Eclipse 快捷键技巧 + 重构
▪win7 打开防火墙端口    ▪Linux Shell脚本入门--awk命令详解    ▪Linux Shell脚本入门--Uniq命令
▪Linux(Android NDK)如何避免僵死进程    ▪http Content-Type一览表    ▪Redis实战之征服 Redis + Jedis + Spring (二)
▪Tomcat7.0.40 基于DataSourceRealm的和JDBCRealm的资源...    ▪利用SQOOP将ORACLE到HDFS    ▪django输出 hello world
▪python re    ▪unity3D与网页的交互    ▪内存共享基本演示
▪python join    ▪不再为无限级树结构烦恼,且看此篇    ▪python实现变参
▪打开文件数限制功能不断地制造问题    ▪Arduino Due, Maple and Teensy3.0 的 W5200性能测试    ▪Selenium实例----12306网站测试
▪基于协同过滤的推荐引擎    ▪C4.5决策树    ▪C#HTTP代理的实现之注册表实现
▪nosql和关系型数据库比较?    ▪如何快速比较这两个字符串是否相等?    ▪hdoj 1863 畅通工程 最小生成树---prime算法
 


站内导航:


特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

©2012-2021,,E-mail:www_#163.com(请将#改为@)

浙ICP备11055608号-3