861. 翻转矩阵后的得分

思路:

行首的权值最大,故首先将其置1;

每列由于权值相同,故只需要将0多于1的情况反转即可

763. 划分字母区间

思路:

1.计算每个字母的最右边界下标,并记录到新数组中

2.通过遍历原数组,当下标与当前的最右边界相等时,即表示当前字母可以覆盖前面所有字母的最右边界;

划分出新区间,同时当前的下标更新为新区间的左边界

122. 买卖股票的最佳时机 II

思路:

每当后面的数比前一个数大,就将其差价加到利润中

765. 情侣牵手

思路:

确定对应的情侣数(0对1,2对3,,,),查找并将其替换

860. 柠檬水找零

思路:

  判断是否为5,10,20;是则按数量找零,零钱不够时返回false

 bool lemonadeChange(int* bills, int billsSize) {
int i,j,k;
int use[+] = {,,,,};
for (i = ; i < billsSize ; i ++)
{
switch(bills[i])
{
case :
use[]++;break;
case :
use[]++;
if (use[]>)
use[]--;
else
return false;
break;
case :
use[]++;
if (use[]>)
{ if (use[]>)
{
use[]--,use[]--;
}
else if (use[]>)
{
use[] -= ;
}
else
return false;
}
else
return false;
break;
default:return false;
}
} return true;
}

455. 分发饼干

思路:

  先对饼干大小及小孩胃口做降序排列,然后将两者做比较,使用饼干尽可能满足多的小孩

 int findContentChildren(int* g, int gSize, int* s, int sSize) {
int i,j,k,res = ; //对孩子胃口及饼干大小做降序排列
for (i = ; i < gSize ; i ++)
{
k = i;
for (j=i+; j < gSize ; j ++)
{
if (g[j] > g[k])
k = j;
}
if (i != k)
{
g[i] = g[i] ^ g[k];
g[k] = g[i] ^ g[k];
g[i] = g[i] ^ g[k];
}
}
for (i = ; i < sSize ; i ++)
{
k = i;
for (j=i+; j < sSize ; j ++)
{
if (s[j] > s[k])
k = j;
}
if (i != k)
{
s[i] = s[i] ^ s[k];
s[k] = s[i] ^ s[k];
s[i] = s[i] ^ s[k];
}
} //饼干尽可能得满足小孩
for (i=j=; i<gSize && j<sSize ; )
{
if (s[j]>=g[i])
{
i++,j++;
res ++;
}
else
i++;
} return res;
}

621. 任务调度器

思路:

题意要求不同的任务(字母)间必须有n长度的冷却时间,

1.当n=0时:最短时间即为任务的总长度

2.当n>0时

我们先找出数量最多的任务,即可确定大致的最短时间(n+1)*(max-1)

  然后查找是否还有任务的个数是与max相同,个数初始i=1

  最后得到总长度:(n+1)*(max-1)+i

 #define MAX(X,Y) X>Y?X:Y
int leastInterval(char* tasks, int tasksSize, int n) {
int i,j,k;
int arr[];
memset(arr,,sizeof(arr)); //计算各任务的个数
for (i = ; i < tasksSize ; i ++)
arr[tasks[i]-'A'] ++; //降序处理
for (i = ; i < ; i ++)
{
k = i;
for (j = i+ ; j < ; j ++)
if (arr[j] > arr[k])
k = j;
if (k!=i)
{
arr[i] = arr[i] ^ arr[k];
arr[k] = arr[i] ^ arr[k];
arr[i] = arr[i] ^ arr[k];
}
} //计算最短时间
for (i=; i< ; i ++)
if (arr[i] != arr[])
break; return MAX((arr[]-)*(n+)+i,tasksSize);
}

134. 加油站

思路:

先处理数据得到一组加油耗油后的数据

 1.若处理后的数据总和为负数,车必然不能运行,返回-1

2.分别以非负数为起点,遍历一圈看其能否回到原点

 int canCompleteCircuit(int* gas, int gasSize, int* cost, int costSize) {
int i,j,k,res = -;
int use[gasSize];
memset(use,,sizeof(use)); k = ;
//处理得到加油耗油后的数据
for (i = ; i < gasSize ; i ++)
{
use[i] = gas[i]-cost[i];
k += use[i];
} //剩余油量不能为负数
if (k>=)
{
for (i = ; i < gasSize ; i ++)
{
//以非负数为起点
if (use[i]>=)
{
k = use[i];
//遍历一圈看其能否回到原点
for (j=(i+)%gasSize ; j!=i && k> ; j=(j+)%gasSize)
k += use[j];
if (k>= && j==i)
return i;
}
}
} return res;
}

优化代码:

 int canCompleteCircuit(int* gas, int gasSize, int* cost, int costSize) {
int i,totol,sum,start;
totol = sum = start = ;
for (i = ; i < gasSize ; i ++)
{
totol += gas[i]-cost[i];
sum += gas[i]-cost[i];
if (sum<)
{
sum = ;
start = i+;
}
} return totol<?-:start;
}

leedcode_贪心算法系列的更多相关文章

  1. 贪心算法(Greedy Algorithm)

    参考: 五大常用算法之三:贪心算法 算法系列:贪心算法 贪心算法详解 从零开始学贪心算法 一.基本概念: 所谓贪心算法是指,在对问题求解时,总是做出在当前看来是最好的选择.也就是说,不从整体最优上加以 ...

  2. 简答一波 HashMap 常见八股面试题 —— 算法系列(2)

    请点赞,你的点赞对我意义重大,满足下我的虚荣心. Hi,我是小彭.本文已收录到 GitHub · Android-NoteBook 中.这里有 Android 进阶成长知识体系,有志同道合的朋友,关注 ...

  3. 算法导论----贪心算法,删除k个数,使剩下的数字最小

    先贴问题: 1个n位正整数a,删去其中的k位,得到一个新的正整数b,设计一个贪心算法,对给定的a和k得到最小的b: 一.我的想法:先看例子:a=5476579228:去掉4位,则位数n=10,k=4, ...

  4. LEETCODE —— Best Time to Buy and Sell Stock II [贪心算法]

    Best Time to Buy and Sell Stock II Say you have an array for which the ith element is the price of a ...

  5. ACM_ICPC hdu-2111(简单贪心算法)

    一道非常简单的贪心算法,但是要注意输入的价值是单位体积的价值,并不是这个物品的总价值!#include <iostream> #include <stdio.h> #inclu ...

  6. 基于贪心算法的几类区间覆盖问题 nyoj 12喷水装置(二) nyoj 14会场安排问题

    1)区间完全覆盖问题 问题描述:给定一个长度为m的区间,再给出n条线段的起点和终点(注意这里是闭区间),求最少使用多少条线段可以将整个区间完全覆盖 样例: 区间长度8,可选的覆盖线段[2,6],[1, ...

  7. 增强学习贪心算法与Softmax算法

    (一) 这个算法是基于一个概率来对探索和利用进行折中:每次尝试时,以概率进行探索,即以均匀概率随机选取一个摇臂,以的概率进行利用,即以这个概率选择当前平均奖赏最高的摇臂(如有多个,则随机选取). 其中 ...

  8. JAVA算法系列 冒泡排序

    java算法系列之排序 手写冒泡 冒泡算是最基础的一个排序算法,简单的可以理解为,每一趟都拿i与i+1进行比较,两个for循环,时间复杂度为 O(n^2),同时本例与选择排序进行了比较,选择排序又叫直 ...

  9. JAVA算法系列 快速排序

    java算法系列之排序 手写快排 首先说一下什么是快排,比冒泡效率要高,快排的基本思路是首先找到一个基准元素,比如数组中最左边的那个位置,作为基准元素key,之后在最左边和最右边设立两个哨兵,i 和 ...

随机推荐

  1. Linux 下 SVN服务器搭建

    使用Linux(CentOS)搭建SVN服务器全攻略 虽然在windows上搭建SVN很简单,但是效能却不高,这当然是和linux相比了.然而在linux上搭建SVN却非常繁琐,所以今天这篇文章就来一 ...

  2. select标签(分组下拉菜单和列表)

    分组下拉菜单和列表标签: <select name=" " > <optgroup label="组1"> <option val ...

  3. 20155219 《Java程序设计》实验一(Java开发环境的熟悉)实验报告

    一.实验内容及步骤 1.使用JDK编译.运行简单的java程序 先在命令行中按老师要求输入,之后编译运行,如下图. 具体代码如下: package src.shiyan1; import java.u ...

  4. 工作记录[续] android OBB

    前两篇在这里: Android上使用native IO 最近工作中的问题笔记 最近遇到的问题是, java.io.IOException: FAT Full StackOverflow的结果: htt ...

  5. SpringMVC(二)高级

    高级参数绑定 1.1. 绑定数组 1.1.1. 需求 在商品列表页面选中多个商品,然后删除. 1.1.2. 需求分析 功能要求商品列表页面中的每个商品前有一个checkbok,选中多个商品后点击删除按 ...

  6. fastdfs(https://www.jianshu.com/p/1c71ae024e5e)

    参考 官方网站:https://github.com/happyfish100/ 配置文档:https://github.com/happyfish100/fastdfs/wiki/ 参考资料:htt ...

  7. mongodb备份与还原

    mongodb单机: 备份所有的库: mongodump --host 10.10.7.33:27019 --gzip --out /home/mongodb/0415_bf 备份指定的库: mong ...

  8. sqler sql 转rest api 的docker image

    最新sqler 又发布了一个版本,同时官方文档也更新,对于数据库的连接有了详细的说明 Dockerfile 为了方便以及减少大小,使用多阶段构建,同时都通过环境变量运行 FROM alpine:lat ...

  9. Gravitee.io 架构

    Gravitee.io 官方文档提供了几张架构图,通过图我们可以有一个整体的认识. 全局架构 平台架构 参考资料 https://docs.gravitee.io/apim_overview_arch ...

  10. Promise实例的catch方法

    //Promise.prototype.catch方法是.then(null,rejection)的别名, //用于指定发生错误时的回调函数 //then方法指定的回调函数如果运行时抛出错误,也会被c ...