4/4 这周莫名得忙,一天是做编译,一天是做模式识别作业,(一天刷魔兽皮肤),周末玩了两天,总的来说还是松懈了,大概只做了两天的leetcode,刷了10道题,羞愧羞愧。

决定每次把代码附上在这个总结里,一来是方便,二来是有利于以后回顾。(其实想找一个更好的排列方法,以后再说吧)


283. Move Zeroes

将数组中的0移到数组末尾,是正常的for循环,不过in-place要考虑一下了,总之我看了答案

依次调换,同时记录非0的个数

(万恶的校园网,贴不上代码)

237. Delete Node in a Linked List

删除链表节点,答案很奇怪,也想知道为啥,这种解答我可以理解

class Solution {
public:
void deleteNode(ListNode* node) {
node->val = node->next->val;
node->next = node->next->next;
}
};

但这种解答我就不知为什么

void deleteNode(ListNode* node) {
*node = *node->next;
}

换成这样就运行失败

void deleteNode(ListNode* node) {
node = node->next;
}

算是个不懂的地方

260. Single Number III

返回数组中出现是single number,因为是多个numbers,所以用vector加上push_back()返回,很方便

class Solution {
public:
vector<int> singleNumber(vector<int>& nums) {
sort(nums.begin(),nums.end());
vector<int> single;
int i = ;
if(nums[i]!=nums[i+])
{
single.push_back(nums[i]);
}
for(i=;i<nums.size()-;i++)
{
if(nums[i]!=nums[i-]&&nums[i]!=nums[i+])
{
single.push_back(nums[i]);
}
}
if(nums[i]!=nums[i-])
{
single.push_back(nums[i]);
}
return single;
}
};

100. Same Tree

判断两个树是否完全相同,看上去很简单,但是返回值是时候难到我了,如何在子树(即递归多次以后)发现不同的时候,将结果正确地返回到第一层递归里,而且不用全局,看了答案才发现自己太蠢了,简单的尾递归。算是有了解了吧。

238. Product of Array Except Self

数组对应的值和其他值相乘,算上有一个0的边界条件和有2个以上0的边界条件即可

class Solution {
public:
vector<int> productExceptSelf(vector<int>& nums) {
int ele = ;
int count0 = ;
for(int i=;i<nums.size();i++){
if(nums[i]==) count0++;
else ele = ele*nums[i];
} if(count0>)
{
for(int i=;i<nums.size();i++)
{
nums[i] = ;
}
}
else if(count0==)
{
for(int i=;i<nums.size();i++)
{
if(nums[i]== ) nums[i] = ele;
else nums[i] = ;
}
}
else
{
for(int i=;i<nums.size();i++)
{
if(nums[i]== ) nums[i] = ele;
else nums[i] = ele/nums[i];
}
}
return nums;
}
};

242. Valid Anagram

For example,
s = "anagram", t = "nagaram", return true.
s = "rat", t = "car", return false.

这我想得很复杂,看了答案真是羞愧,应该多用用int数组了,创建一个长度26的数组。

class Solution {
public:
bool isAnagram(string s, string t) {
if(s.size()!=t.size())
{
return false;
}
int n = s.size();
int count[] = {};
for(int i = ;i < n;i++)
{
count[s[i] - 'a']++;
count[t[i] - 'a']--;
}
for(int j = ;j < ;j++)
{
if(count[j]) return false;
}
return true;
}
};

168. Excel Sheet Column Title

1 -> A 2 -> B 3 -> C
...
26 -> Z 27 -> AA 28 -> AB

简单的余数和除数的题,回顾了一下

class Solution {
public:
string convertToTitle(int n) {
int x,y;
string s = "";
while(n)
{
x = (n-)/;
y = (n-)%;
if(y)
{
string s1 = "";
s1 += y+'A' ;
s = s1 + s;
}
else
{
s = 'A' + s; }
n = x;
} return s;
}
};

171. Excel Sheet Column Number

和上一题相反的题,根据string返回int,已知string长度(.size())那就简单很多了

(gtmd校园网,gtmd方校长,网页又崩了)

217. Contains Duplicate

判断数组中是否有相同数,先sort再for,水题。

class Solution {
public:
bool containsDuplicate(vector<int>& nums) {
if(nums.size()<) return false;
sort(nums.begin(),nums.end());
for(int i = ;i < nums.size()-;i++)
{
if(nums[i]==nums[i+]) return true;
}
return false;
}
};

319. Bulb Switcher

灯泡问题,我先写了一个长的代码,结果999999超时

        vector<int> nums(n,);
if(n==) return ;
if(n==) return ;
for(int i = ;i <= n;i++ )
{
if(i==)
{
for(int j=;j<n;j=j+)
{
nums[j] = ;
}
}
else if(i<n)
{
for(int j=i-;j<n;j=j+i)
{
nums[j] = nums[j]^;
}
}
else if(i==n)
{
nums[n-] = nums[n-]^;
}
}
int counts = ;
for(int j=;j<n;j++)
{
if(nums[j]) counts++;
}
return counts;

结果答案是直接返回sqrt。。

class Solution {
public:
int bulbSwitch(int n) {
/*
vector<int> nums(n,1);
if(n==0) return 0;
if(n==1) return 1;
for(int i = 1;i <= n;i++ )
{
if(i==2)
{
for(int j=1;j<n;j=j+2)
{
nums[j] = 0;
}
}
else if(i<n)
{
for(int j=i-1;j<n;j=j+i)
{
nums[j] = nums[j]^1;
}
}
else if(i==n)
{
nums[n-1] = nums[n-1]^1;
}
}
int counts = 0;
for(int j=0;j<n;j++)
{
if(nums[j]) counts++;
}
return counts;
*/
return sqrt(n);
}
};

169. Majority Element

返回一个占数组超过一半的数(一定存在)

先sort,然后直接取中间数,机智如我

class Solution {
public:
int majorityElement(vector<int>& nums) {
sort(nums.begin(),nums.end());
return nums[nums.size()/];
}
};

第二周leetcode的更多相关文章

  1. 第二周 Leetcode 493. Reverse Pairs(HARD)

    leetcode 493跟经典的逆序对问题没有什么区别, 首先考虑对数组前半部和后半部求逆序对数,若能保证两段数组都有序,则显然可以在线性时间内求出对数. 所以我们采用归并排序的方法,一方面让数组有序 ...

  2. ARTS第二周

    第二周. 1.Algorithm:每周至少做一个 leetcode 的算法题2.Review:阅读并点评至少一篇英文技术文章3.Tip:学习至少一个技术技巧4.Share:分享一篇有观点和思考的技术文 ...

  3. Surprise团队第二周项目总结

    Surprise团队第二周项目总结 项目进展 已实现五子棋人人模式部分 人人模式: 基本方式:采取黑棋先行,黑白交替的下棋顺序. 模式:通过鼠标点击相应棋盘中的"交叉点",在lay ...

  4. python课程第二周重点记录

    python课程第二周重点记录 1.元组的元素不可被修改,元组的元素的元素可以被修改(字典在元组中,字典的值可以被修改) 2.个人感觉方便做加密解密 3.一些方法的使用 sb = "name ...

  5. 20145213《Java程序设计》第二周学习总结

    20145213<Java程序设计>第二周学习总结 教材学习内容总结 本周娄老师给的任务是学习教材的第三章--基础语法.其实我觉得还蛮轻松的,因为在翻开厚重的书本,一股熟悉的气息扑面而来, ...

  6. 20145304 刘钦令 Java程序设计第二周学习总结

    20145304 <Java程序设计>第2周学习总结 教材学习内容总结 java可区分基本类型和类类型(即参考类型)两大类型系统. 基本类型主要可区分为整数.字节.浮点数.字符与布尔. 整 ...

  7. 20145330孙文馨 《Java程序设计》第二周学习总结

    20145330孙文馨第二周学习总结 第二周相比于第一周对java语言有了深一点的了解,也意识到多敲代码才是学习计算机语言的最好方法. 教材内容总结 类型.变量与运算符 *基本类型 整数(short. ...

  8. 20145337 《Java程序设计》第二周学习总结

    20145337 <Java程序设计>第二周学习总结 教材学习内容总结 Java可分基本类型与类类型: 基本类型分整数(short.int.long).字节(byte).浮点数(float ...

  9. Linux内核设计第二周——操作系统工作原理

    Linux内核设计第二周 ——操作系统工作原理 作者:宋宸宁(20135315) 一.实验过程 图1 执行效果 从图中可以看出,每执行my_ start_ kernel函数两次或一次,my_ time ...

随机推荐

  1. 智能家居入门DIY——【一、ESP8266之软串口HTTP请求】

    前段时间做了一个激光雕刻,玩的不亦乐乎.对Arduino大感兴趣,于是又入手一块20大洋版,配上买学习套件时的诸多零件——红外发射管.一体化红外接收头.DHT11温湿度传感器.ESP8266等,以及某 ...

  2. jsp---猜数字游戏,深有感触

    猜数字游戏注意两点.1.随机数和猜的数字不能放在同一个页面,不然随机数不停出现,猜的数字不可能相等的. 2.数据类型的相互转换.包装类Integer和int的用法,前者是类,后者是基本数据类型 cai ...

  3. 关于AOP无法切入同类调用方法的问题

    一.前言 Spring AOP在使用过程中需要注意一些问题,也就是平时我们说的陷阱,这些陷阱的出现是由于Spring AOP的实现方式造成的.每一样技术都或多或少有它的局限性,很难称得上完美,只要掌握 ...

  4. HDU 3068 最长回文(manachar算法)

    最长回文 Time Limit: 4000/2000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Submis ...

  5. pythonNet day04

    本地套接字 作用:用于本地不同程序间的进行数据传输 本地套接字的创建流程 1.创建套接字对象 sockfd = socket(AF_UNIX,SOCK_STREAM) 2.绑定本地套接字文件,如果文件 ...

  6. Sql2008 全文索引 简明教程

    在SQL Server 中提供了一种名为全文索引的技术,可以大大提高从长字符串里搜索数 据的速度,不用在用LIKE这样低效率的模糊查询了.   下面简明的介绍如何使用Sql2008 全文索引 一.检查 ...

  7. 温故而知新-array_walk和sizeof和array_count_values()和extract()

    1 array_walk对数组的每一个元素应用任何函数 用户自定义函数中的第一个参数指定为引用:&$value,来改变数组元素的值 如果对一个参数使用取地址,那么会改变数组元素的值 2 siz ...

  8. shell脚本实现tomcat进程—查、杀、启

    #!/bin/bash#获取XXX项目进程IDXXXpid=`ps -ef | grep XXX | grep -v grep | awk '{print $2}'` echo "XXX项目 ...

  9. HTTP 协议基础

    HTTP 协议的主要特点可概括如下: 1.支持客户/服务器模式. 2.简单快速:客户向服务器请求服务时,只需传送请求方法和路径.请求方法常用的有GET.HEAD.POST.每种方法规定了客户与服务器联 ...

  10. VB.Net条形码编程的方法

    一.条形码的读取用过键盘口式的扫条码工具的朋友就知道,它就如同在鍵盘上按下数字鍵一样,基本不需任何编程和处理.但如果你使用的是其它接口的话,可能你就要为该设备编写通讯代码了.以下有一段简单的25针串口 ...