【LeetCode】Algorithms 题集(三)
Search Insert Position
意:
Given a sorted array and a target value, return the index if the target is found. If not, return the index where it would be if it were inserted in order.
You may assume no duplicates in the array.
Here are few examples.
[1,3,5,6], 5 → 2
[1,3,5,6], 2 → 1
[1,3,5,6], 7 → 4
[1,3,5,6], 0 → 0
思路:
给定一个有序数组。和一个目标元素,假设目标元素存在。则给出其在数组中相应的下标。不存在则返回一个整数。表明目标元素应该插入到数组中的位置。
非常easy的一道题。仅仅要遍历数组,有下面情况:
1. 假设找到该元素。直接返回其下标
2. 遇到第一个比它大数。返回这个数的下标。
3. 找不到比它大的数,那么应该插入到最后,返回 n。
情况 1 2 能够写在一起。
代码:
class Solution {
public:
int searchInsert(int A[], int n, int target) {
for(int i = 0;i < n;i++)
{
if(A[i] >= target)
return i;
}
return n;
}
};
Excel Sheet Column Number
题意:
Related to question Excel Sheet Column Title
Given a column title as appear in an Excel sheet, return its corresponding column number.
For example:
A -> 1
B -> 2
C -> 3
...
Z -> 26
AA -> 27
AB -> 28
思路:
事实上就是个进制转换。水水就过。
假设你用 Python 的话记得获取字母的 ASCII 码要用 ord 函数,不能直接强制类型转换。
代码:
class Solution {
public:
int titleToNumber(string s) {
int len = s.size();
int ans = 0;
for(int i = 0;i < len;++i)
ans = ans*26 + s[i] - 'A' + 1;
return ans;
}
};
Remove Duplicates from Sorted List
题意:
Given a sorted linked list, delete all duplicates such that each element appear only once.
For example,
Given 1->1->2, return 1->2.
Given 1->1->2->3->3, return 1->2->3.
思路:
删除链表中的反复项,考察链表操作。
主要是用循环推断当前节点和下一级节点的值是否同样,是则改动当前节点的 next 指针指向下一节点的 next。
注意操作时要推断指针非空。
代码:
/**
* Definition for singly-linked list.
* struct ListNode {
* int val;
* ListNode *next;
* ListNode(int x) : val(x), next(NULL) {}
* };
*/
class Solution {
public:
ListNode *deleteDuplicates(ListNode *head){
/*保存头指针*/
ListNode* root = head; while(head != NULL)
{
/*下一节点存在,且当前节点和下一节点的值反复*/
while(head->next != NULL && head->val == head->next->val)
{
head->next = head->next->next;
}
head = head->next;
}
return root;
}
};
N-Queens
题意
The n-queens puzzle is the problem of placing n queens on an n×n chessboard such that no two queens attack each other.

Given an integer n, return all distinct solutions to the n-queens puzzle.
Each solution contains a distinct board configuration of the n-queens' placement, where 'Q' and '.' both
indicate a queen and an empty space respectively.
For example,
There exist two distinct solutions to the 4-queens puzzle:
[
[".Q..", // Solution 1
"...Q",
"Q...",
"..Q."], ["..Q.", // Solution 2
"Q...",
"...Q",
".Q.."]
]
思路
n 皇后问题。但要输出每一个解。仅仅要对每一行进行递归下去就好。
代码
class Solution {
public:
vector<vector<string> > solveNQueens(int n) {
/*初始化 vector 变量,第 i 个数代表第 i 行的皇后在哪一列*/
vector<int> chess(n,-1);
/*保存结果*/
vector< vector<string> > ans;
/*解决这个问题*/
solveQueen(0,n,chess.begin(),ans);
return ans;
}
void solveQueen(int r,int n,vector<int>::iterator chess,vector< vector<string> > &ans)
{
/*r 等于 n 时每一行都有了皇后*/
if(r == n)
{
/*solution 用于保存一个合法解*/
vector<string> solution;
for(int i = 0;i < n;++i)
{
solution.push_back(getRowInString(n,*(chess+i)));
}
ans.push_back(solution);
return;
}
/*对当前行看哪一列能够放皇后*/
for(int i = 0;i < n;++i)
{
*(chess+r) = i;
/*检查合法性*/
if(check(chess,r,n))
{
/*向下递归*/
solveQueen(r+1,n,chess,ans);
}
}
}
/*检查冲突*/
bool check(vector<int>::iterator chess,int r,int n)
{
/*对之前的每一行*/
for(int i = 0;i < r;++i)
{
/*计算两列的距离*/
int dis = abs(*(chess+r) - *(chess+i));
/* dis = 0 则在同一列。 dis = r- 1 则构成等腰三角形。即对角线*/
if(dis == 0 || dis == r - i)
return false;
}
return true;
}
/*构造 n 个长度的在 col 为皇后的 string */
string getRowInString(int n,int col)
{
string str(n,'.');
str.replace(col,1,"Q");
return str;
}
};
N-Queens II
题意:
Follow up for N-Queens problem.
Now, instead outputting board configurations, return the total number of distinct solutions.

思路:
n 皇后问题,算可能的方案数。
主要的简单想法是对每一行处理。处理的时候尝试在每一列放一个皇后,仅仅要不冲突就向下递归,不断计算合法方案数。
代码:
class Solution {
public:
int totalNQueens(int n) {
/*初始化 vector 变量。第 i 个数代表第 i 行的皇后在哪一列*/
vector<int> chess(n,-1);
int ans = 0;
/*解决这个问题*/
solveQueen(0,n,chess.begin(),ans);
return ans;
}
void solveQueen(int r,int n,vector<int>::iterator chess,int &ans)
{
/*r 等于 n 时每一行都有了皇后*/
if(r == n)
{
ans++;
return;
}
/*对当前行看哪一列能够放皇后*/
for(int i = 0;i < n;++i)
{
*(chess+r) = i;
/*检查合法性*/
if(check(chess,r,n))
{
/*向下递归*/
solveQueen(r+1,n,chess,ans);
}
}
}
/*检查冲突*/
bool check(vector<int>::iterator chess,int r,int n)
{
/*对之前的每一行*/
for(int i = 0;i < r;++i)
{
/*计算两列的距离*/
int dis = abs(*(chess+r) - *(chess+i));
/* dis = 0 则在同一列, dis = r- 1 则构成等腰三角形。即对角线*/
if(dis == 0 || dis == r - i)
return false;
}
return true;
}
};
版权声明:本文博客原创文章。博客,未经同意,不得转载。
【LeetCode】Algorithms 题集(三)的更多相关文章
- leetcode刷题第三天<无重复字符的最长子串>
给定一个字符串,请你找出其中不含有重复字符的 最长子串 的长度. 示例 : 输入: "abcabcbb" 输出: 解释: 因为无重复字符的最长子串是 . 示例 : 输入: &quo ...
- 算法笔记_116:算法集训之代码填空题集三(Java)
目录 1 数组转置 2 文件管理 3 显示为树形 4 杨辉三角系数 5 圆周率与级数 6 整数翻转 7 自行车行程 8 祖冲之割圆法 9 最大5个数 10 最大镜像子串 1 数组转置 编写程序将 ...
- LeetCode算法题-Move Zeroes(Java实现-三种解法)
这是悦乐书的第201次更新,第211篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第67题(顺位题号是283).给定一个数组nums,写一个函数将所有0移动到它的末尾,同 ...
- LeetCode算法题-First Bad Version(Java实现-三种解法)
这是悦乐书的第200次更新,第210篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第66题(顺位题号是278).您是产品经理,目前领导团队开发新产品.不幸的是,您产品的最 ...
- LeetCode算法题-Subdomain Visit Count(Java实现)
这是悦乐书的第320次更新,第341篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第189题(顺位题号是811).像"discuss.leetcode.com& ...
- LeetCode算法题-Number of Lines To Write String(Java实现)
这是悦乐书的第319次更新,第340篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第188题(顺位题号是806).我们要将给定字符串S的字母从左到右写成行.每行最大宽度为 ...
- LeetCode算法题-Unique Morse Code Words(Java实现)
这是悦乐书的第318次更新,第339篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第186题(顺位题号是804).国际莫尔斯电码定义了一种标准编码,其中每个字母映射到一系 ...
- LeetCode算法题-Rotate String(Java实现)
这是悦乐书的第317次更新,第338篇原创 在开始今天的算法题前,说几句,今天是世界读书日,推荐两本书给大家,<终身成长>和<禅与摩托车维修艺术>,值得好好阅读和反复阅读. 0 ...
- LeetCode算法题-Rotated Digits(Java实现)
这是悦乐书的第316次更新,第337篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第185题(顺位题号是788).如果一个数字经过180度旋转后,变成了一个与原数字不同的 ...
随机推荐
- hdu2242(树形dp+tarjan+缩点)
hdu2242 http://acm.hdu.edu.cn/showproblem.php?pid=2242 给定n,m表示n个点,m条边 每个点有个权值 问我们删除两某条边(割边)后将图分为两个部分 ...
- Linux内核源代码的学习过程转换完成细节
linux中的进程是个最主要的概念,进程从执行队列到開始执行有两个開始的地方, 一个就是switch_to宏中的标号1:"1:/t",//仅仅要不是新创建的进程,差点儿都是从上面的 ...
- Oracle安装过程物理内存检查及临时temp空间不足解决办法
物理内存 – 此先决条件将测试系统物理内存总量是否至少为 922MB (944128.0KB). 预期值 : N/A 实际值 : N/A 错误列表: – 可用物理内存 PRVF-7531 : 无法在节 ...
- ubuntu10.10和windows双系统启动顺序的修改
我想大部分童鞋装ubuntu的时候,硬盘上的windows肯定还是保留着的,启动电 脑时可以选择,想进windows就进windows,想进ubuntu就进ubuntu.但装完ubuntu后,它默认启 ...
- C# 隐藏 Windows Phone 侦错模式中萤幕右上角的数据条(模拟器、实机可用),截图好方便。
原文:C# 隐藏 Windows Phone 侦错模式中萤幕右上角的数据条(模拟器.实机可用),截图好方便. 一般我们在开发Windows Phone App时,会使用模拟器或是实体的手机开发,在Vi ...
- Zoj 3545 Rescue the Rabbit(ac自己主动机+dp)
标题效果: 鉴于DNA有一个正确的顺序值.请构造一个长度I的DNA在这个序列使DNA正确的顺序值极大.它被认为是负的输出噼啪. .. IDEAS: 施工顺序是,ac己主动机上走,求最大要用到dp dp ...
- 让Android系统支持ubifs文件系统
原文地址:http://www.cnblogs.com/linucos/p/3279381.html 1. ubifs号称性能比yaffs2 好,同时压缩可读写,文件系统image体较小同时可写,相当 ...
- Android异步任务
本文主要探讨Android平台提供的各种异步载入机制,包括它们的适用场景.用法等. 1. AsynTask AsynTask适用于最长能够持续几秒钟的短时间的操作,对于长时间的操作,建议使用java. ...
- POJ--2923--Relocation--如压力DP
Relocation Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 2288 Accepted: 950 Descrip ...
- ECG信号读出,检测QRS,P,T 波(小波去噪,并根据检测),基于BP辨识的神经网络
这学期的课程选择神经网络.最后的作业处理ECG信号,并利用神经网络识别. 1 ECG引进和阅读ECG信号 1)ECG介绍 详细ECG背景应用就不介绍了,大家能够參考百度 谷歌.仅仅是简单说下ECG ...