61-65题 题解

61Rotate List

Given a list, rotate the list to the right by k places, where k is non-negative.


Example:

Given 1->2->3->4->5->NULL and k = 2,

return 4->5->1->2->3->NULL.
//如果k大于链表长度时,应该旋转 k%len
//一个快指针,一个慢指针,快的指针比慢的先走k个,这样当快的指针走到NULL时,慢的刚好是倒数第k个
/**
 * Definition for singly-linked list.
 * struct ListNode {
 *     int val;
 *     ListNode *next;
 *     ListNode(int x) : val(x), next(NULL) {}
 * };
 */
class Solution {
public:
    ListNode* rotateRight(ListNode* head, int k) {
        if(!head || !head->next) return head;
        ListNode *p, *q;
        p = q = head;
        int len = 0;
        while(p)
        {
            p = p->next;
            len++;
        }
        k %= len;
        if(k == 0) return head;
        p = head;
        while(p && k--)
        {
            p = p->next;
        }
        if(!p) return head;
        while(p->next)
        {
            p = p->next;
            q = q->next;
        }
        ListNode *cur = q->next;
        q->next = NULL;
        p->next = head;
        return cur;
    }
};
62 Unique Paths

A robot is located at the top-left corner of a m x n grid (marked 'Start' in the diagram below).

The robot can only move either down or right at any point in time. The robot is trying to reach the bottom-right corner of the grid (marked 'Finish' in the diagram below).

How many possible unique paths are there?


Above is a 3 x 7 grid. How many possible unique paths are there?

Note: m and n will be at most 100.

//记忆化搜索,暴力搜索会超时,动态规划也可以写,其实记忆化搜索就是变相的DP
class Solution {
public:
    int vis[101][101];
    int dfs(int i, int j, int m, int n)
    {
        if(vis[i][j]) return vis[i][j];
        if(i == m && n == j) return 1;
        int a, b;
        a = b = 0;

        if(i < m) a = vis[i+1][j] = dfs(i+1, j, m, n);
        if(j < n) b = vis[i][j+1] = dfs(i, j+1, m, n);
        return a + b;
    }
    int uniquePaths(int m, int n) {
        memset(vis, 0, sizeof(vis));
        return dfs(1, 1, m, n);
    }
};


63 Unique Paths II

Follow up for "Unique Paths":

Now consider if some obstacles are added to the grids. How many unique paths would there be?

An obstacle and empty space is marked as 1 and 0 respectively in the grid.

For example,

There is one obstacle in the middle of a 3x3 grid as illustrated below.

[
  [0,0,0],
  [0,1,0],
  [0,0,0]
]

The total number of unique paths is 2.

Note: m and n will be at most 100.

//同上一题
class Solution {
public:
    int vis[101][101];
    int dfs(int i, int j, int m, int n, vector<vector<int>>& obstacleGrid)
    {
        if(vis[i][j] != -1) return vis[i][j];
        if(i == m && n == j) return 1;
        int a, b;
        a = b = 0;

        if(i < m && !obstacleGrid[i+1][j]) a = vis[i+1][j] = dfs(i+1, j, m, n, obstacleGrid);
        if(j < n && !obstacleGrid[i][j+1]) b = vis[i][j+1] = dfs(i, j+1, m, n, obstacleGrid);
        return a + b;
    }
    int uniquePathsWithObstacles(vector<vector<int>>& obstacleGrid) {
        if(obstacleGrid.size() == 0) return 0;
        memset(vis, -1, sizeof(vis));
        int m = obstacleGrid.size()-1;
        int n = obstacleGrid[0].size()-1;
        if(obstacleGrid[m][n] || obstacleGrid[0][0]) return 0;
        return dfs(0, 0, m, n, obstacleGrid);
    }
};


64 Minimum Path Sum

Given a m x n grid filled with non-negative numbers, find a path from top left to bottom right which minimizes the sum of all numbers along its path.

Note: You can only move either down or right at any point in time.

Example 1:

[[1,3,1],
 [1,5,1],
 [4,2,1]]
Given the above grid map, return  7. Because the path 1→3→1→1→1 minimizes the sum.

//同上一题,也可以DP
class Solution {
public:
    int vis[509][509];
    int dfs(int i, int j, int m, int n, vector<vector<int>>& grid)
    {
        if(vis[i][j] != 0x3f3f3f3f) return vis[i][j];
        if(i == m && n == j) return grid[m][n];
        if(i < m)
        {
            int k = dfs(i+1, j, m, n, grid);
            vis[i][j] = min(vis[i][j], k+grid[i][j]);
        }
        if(j < n)
        {
            int k = dfs(i, j+1, m, n, grid);
            vis[i][j] = min(vis[i][j], k+grid[i][j]);
        }
        return vis[i][j];
    }
    int minPathSum(vector<vector<int>>& grid) {
        if(grid.size() == 0) return 0;
        memset(vis, 0x3f, sizeof(vis));
        return dfs(0, 0, grid.size()-1, grid[0].size()-1, grid);
    }
};
65 Valid Number

Validate if a given string is numeric.

Some examples:
"0" => true
" 0.1 " => true
"abc" => false
"1 a" => false
"2e10" => true

Note: It is intended for the problem statement to be ambiguous. You should gather all requirements up front before implementing one.

Update (2015-02-10):
The signature of the C++ function had been updated. If you still see your function signature accepts a const char * argument, please click the reload button  to reset your code definition.

//WA了十万发,终于给A了,需要判断的地方有很多
// . + - ' ' e E等
class Solution {
public:
    bool isNumber(string s) {
        int len = s.length();

        int falg = 0, i = 0;
        while(i < len && s[i] == ' ') i++;
        if(len == i) return false;
        while(i < len)
        {
            if(isdigit(s[i])) i++;
            else if((s[i] == 'e' || s[i] == 'E') && falg != 2)
            {
                if(i == 0 || s[i-1] == ' ') return false;
                if(((i+1 < len) && isdigit(s[i+1])) || ((i+2 < len)&&((s[i+1] == '-'||s[i+1]=='+') && isdigit(s[i+2])))) i += 2;
                else return false;
                falg = 2;
            }
            else if(s[i] == '-' || s[i] == '+')
            {
                if(i - 1 >= 0 && isdigit(s[i-1])) return false;
                if((i+1 < len && isdigit(s[i+1])) || (i+2 < len && s[i+1] == '.' && isdigit(s[i+2]))) i += 2;
                else return false;
            }
            else if(s[i] == '.' && !falg)
            {
                i++;
                if(i < len && isdigit(s[i])) i++;
                else if(i - 2 >= 0 && isdigit(s[i-2])) ;
                else return false;
                falg = 1;
            }
            else if(s[i] == ' ')
            {
                while(i < len && s[i] == ' ') i++;
                if(i == len) return true;
                return false;
            }
            else return false;
        }
        return true;
    }
};




  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
【项目资源】:包含前端、后端、移动开发、操作系统、人工智能、物联网、信息化管理、数据库、硬件开发、大数据、课程资源、音视频、网站开发等各种技术项目的源码。包括STM32、ESP8266、PHP、QT、Linux、iOS、C++、Java、MATLAB、python、web、C#、EDA、proteus、RTOS等项目的源码。 【项目质量】:所有源码都经过严格测试,可以直接运行。功能在确认正常工作后才上传。 【适用人群】:适用于希望学习不同技术领域的小白或进阶学习者。可作为毕设项目、课程设计、大作业、工程实训或初期项目立项。 【附加价值】:项目具有较高的学习借鉴价值,也可直接拿来修改复刻。对于有一定基础或热衷于研究的人来说,可以在这些基础代码上进行修改和扩展,实现其他功能。 【沟通交流】:有任何使用上的问,欢迎随时与博主沟通,博主会及时解答。鼓励下载和使用,并欢迎大家互相学习,共同进步。【项目资源】:包含前端、后端、移动开发、操作系统、人工智能、物联网、信息化管理、数据库、硬件开发、大数据、课程资源、音视频、网站开发等各种技术项目的源码。包括STM32、ESP8266、PHP、QT、Linux、iOS、C++、Java、MATLAB、python、web、C#、EDA、proteus、RTOS等项目的源码。 【项目质量】:所有源码都经过严格测试,可以直接运行。功能在确认正常工作后才上传。 【适用人群】:适用于希望学习不同技术领域的小白或进阶学习者。可作为毕设项目、课程设计、大作业、工程实训或初期项目立项。 【附加价值】:项目具有较高的学习借鉴价值,也可直接拿来修改复刻。对于有一定基础或热衷于研究的人来说,可以在这些基础代码上进行修改和扩展,实现其他功能。 【沟通交流】:有任何使用上的问,欢迎随时与博主沟通,博主会及时解答。鼓励下载和使用,并欢迎大家互相学习,共同进步。【项目资源】:包含前端、后端、移动开发、操作系统、人工智能、物联网、信息化管理、数据库、硬件开发、大数据、课程资源、音视频、网站开发等各种技术项目的源码。包括STM32、ESP8266、PHP、QT、Linux、iOS、C++、Java、MATLAB、python、web、C#、EDA、proteus、RTOS等项目的源码。 【项目质量】:所有源码都经过严格测试,可以直接运行。功能在确认正常工作后才上传。 【适用人群】:适用于希望学习不同技术领域的小白或进阶学习者。可作为毕设项目、课程设计、大作业、工程实训或初期项目立项。 【附加价值】:项目具有较高的学习借鉴价值,也可直接拿来修改复刻。对于有一定基础或热衷于研究的人来说,可以在这些基础代码上进行修改和扩展,实现其他功能。 【沟通交流】:有任何使用上的问,欢迎随时与博主沟通,博主会及时解答。鼓励下载和使用,并欢迎大家互相学习,共同进步。【项目资源】:包含前端、后端、移动开发、操作系统、人工智能、物联网、信息化管理、数据库、硬件开发、大数据、课程资源、音视频、网站开发等各种技术项目的源码。包括STM32、ESP8266、PHP、QT、Linux、iOS、C++、Java、MATLAB、python、web、C#、EDA、proteus、RTOS等项目的源码。 【项目质量】:所有源码都经过严格测试,可以直接运行。功能在确认正常工作后才上传。 【适用人群】:适用于希望学习不同技术领域的小白或进阶学习者。可作为毕设项目、课程设计、大作业、工程实训或初期项目立项。 【附加价值】:项目具有较高的学习借鉴价值,也可直接拿来修改复刻。对于有一定基础或热衷于研究的人来说,可以在这些基础代码上进行修改和扩展,实现其他功能。 【沟通交流】:有任何使用上的问,欢迎随时与博主沟通,博主会及时解答。鼓励下载和使用,并欢迎大家互相学习,共同进步。【项目资源】:包含前端、后端、移动开发、操作系统、人工智能、物联网、信息化管理、数据库、硬件开发、大数据、课程资源、音视频、网站开发等各种技术项目的源码。包括STM32、ESP8266、PHP、QT、Linux、iOS、C++、Java、MATLAB、python、web、C#、EDA、proteus、RTOS等项目的源码。 【项目质量】:所有源码都经过严格测试,可以直接运行。功能在确认正常工作后才上传。 【适用人群】:适用于希望学习不同技术领域的小白或进阶学习者。可作为毕设项目、课程设计、大作业、工程实训或初期项目立项。 【附加价值】:项目具有较高的学习借鉴价值,也可直接拿来修改复刻。对于有一定基础或热衷于研究的人来说,可以在这些基础代码上进行修改和扩展,实现其他功能。 【沟通交流】:有任何使用上的问,欢迎随时与博主沟通,博主会及时解答。鼓励下载和使用,并欢迎大家互相学习,共同进步。【项目资源
大学生在线租房平台管理系统按照操作主体分为管理员和用户。管理员的功能包括报修管理、报修评价管理、字典管理、房东管理、房屋管理、房屋收藏管理、房屋留言管理、房屋租赁管理、租房论坛管理、公告信息管理、留言板管理、用户管理、管理员管理。用户的功能等。该系统采用了Mysql数据库,Java语言,Spring Boot框架等技术进行编程实现。 大学生在线租房平台管理系统可以提高大学生在线租房平台信息管理问的解决效率,优化大学生在线租房平台信息处理流程,保证大学生在线租房平台信息数据的安全,它是一个非常可靠,非常安全的应用程序。 管理员权限操作的功能包括管理公告,管理大学生在线租房平台信息,包括房屋管理,培训管理,报修管理,薪资管理等,可以管理公告。 房屋管理界面,管理员在房屋管理界面中可以对界面中显示,可以对房屋信息的房屋状态进行查看,可以添加新的房屋信息等。报修管理界面,管理员在报修管理界面中查看报修种类信息,报修描述信息,新增报修信息等。公告管理界面,管理员在公告管理界面中新增公告,可以删除公告。公告类型管理界面,管理员在公告类型管理界面查看公告的工作状态,可以对公告的数据进行导出,可以添加新公告的信息,可以编辑公告信息,删除公告信息。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值