问题1描述:【贪婪算法,Dijistra算法】

①有一只兔子要从一个N*N的二维矩阵方格中从上跳到下面;

②每次只能向左或向下,越过一个方格,跳到下一个方格中;

③被越过的方格中的数值,表示该兔子越过该方格后需要休息的时间(或者能量);

求:到达最下面方格花费的最少时间是多少?

输入:

第一行,输入一个数值N

后面输入N行,每行有N个数值并且由【,】隔开

输出:

输出一个数据M,M为兔子需要花费的最小时间

示例:
输入:
6
1,2,3,5,7,6
2,1,4,5,7,4
3,4,5,6,3,6
2,3,1,4,6,8
5,6,1,4,6,2
4,2,4,1,1,6
输出:
6

   

算法1【递归调用】:以后不考虑这种算法

注意:这种方法虽然可以结题,但是如果数据量太大,时间上耗时太多了,每次都不能全部AC,这次只能AC40%

package com.cnblogs.mufasa.demo1;

import java.util.Scanner;

class Answer1_1 {
public static void main(String[] args) {
Scanner scanner = new Scanner(System.in); String line = scanner.nextLine();
int n = Integer.parseInt(line);
int[][] area = new int[n][n]; for (int i = 0; i < n; i++) {
line = scanner.nextLine();
String[] split = line.split(",");
if (split.length != n) {
throw new IllegalArgumentException("错误输入");
}
int j = 0;
for (String num : split) {
area[i][j++] = Integer.parseInt(num);
}
} int minimumTimeCost = getMinimumTimeCost(n,area);
System.out.println(minimumTimeCost);
} /** 请完成下面这个函数,实现题目要求的功能 **/
/** 当然,你也可以不按照这个模板来作答,完全按照自己的想法来 ^-^ **/
private static int getMinimumTimeCost(int n, int[][] area) {
long startTime = System.currentTimeMillis();
int[] nums=new int[n];
for(int i=0;i<n;i++){
nums[i]=getMinSingleLine(n,area,0,i,0);
}
int min=nums[0];
for(int i=1;i<n;i++){
if(min>nums[i]){
min=nums[i];
}
}
long endTime = System.currentTimeMillis();
System.out.println(endTime-startTime);
return min;
} private static int getMinSingleLine(int n,int[][] area,int index0,int index1,int times ){
if(index0==n-2&&(index1==n-1||index1==n-2)){//1,极限位置,正确
return times+area[index0+1][index1];
}else if(index1==n-1||index1==n-2){//2,只能往下走,正确
return getMinSingleLine(n,area,index0+2,index1,times+area[index0+1][index1]);
}else if(index0==n-2){//3,向下一步或向右,正确
return Math.min(times+area[index0+1][index1],getMinSingleLine(n,area,index0,index1+2,times+area[index0][index1+1]));
}else{
return Math.min(getMinSingleLine(n,area,index0+2,index1,times+area[index0+1][index1]),getMinSingleLine(n,area,index0,index1+2,times+area[index0][index1+1]));
}
}
}
/*
8
35,92,98,68,35,65,26,72
29,78,83,16,5,89,92,28
48,51,37,79,65,74,50,71
98,78,99,57,1,30,22,16
72,88,55,33,56,58,28,49
4,28,29,20,18,61,11,73
61,19,47,34,85,32,77,89
29,49,10,81,52,5,63,25
*/

算法2【贪婪算法】:Dijistra算法

算法思路:它和算法1中的原理有点像,但是引入了一个优先队列,每次进行移动都是从耗时最小的那个位置开始移动并且更新队列,当出现第一个到达目的地的数据 时,这个数据就是最快的数据

package com.cnblogs.mufasa.demo1;

import java.util.PriorityQueue;
import java.util.Scanner; public class Answer1_2 {
public static void main(String[] args) {
Scanner scanner = new Scanner(System.in); String line = scanner.nextLine();
int n = Integer.parseInt(line);
int[][] area = new int[n][n]; for (int i = 0; i < n; i++) {
line = scanner.nextLine();
String[] split = line.split(",");
if (split.length != n) {
throw new IllegalArgumentException("错误输入");
}
int j = 0;
for (String num : split) {
area[i][j++] = Integer.parseInt(num);
}
} int minimumTimeCost = getMinimumTimeCost(n,area);
System.out.println(minimumTimeCost);
}
/** 请完成下面这个函数,实现题目要求的功能 **/
/** 当然,你也可以不按照这个模板来作答,完全按照自己的想法来 ^-^ **/
private static int getMinimumTimeCost(int n, int[][] area) {//贪婪算法,每次对优先队列的最小对象进行操作
long startTime = System.currentTimeMillis();
PriorityQueue<Loc> queue=new PriorityQueue<>(3*n);//最小堆实现优先队列
for(int i=0;i<n;i++){//初始化触发机关的位置
queue.add(new Loc(1,i,area[1][i]));
}
Loc preLoc;
while (true){
preLoc=queue.poll();
if(preLoc.index0==n-1){//已经到达目的地
break;
}
if(preLoc.index1==n-2||preLoc.index1==n-1){//右边界情况,只能向下
queue.add(new Loc(preLoc.index0+2,preLoc.index1,preLoc.times+area[preLoc.index0+2][preLoc.index1]));
}else {//可以向下、向右
queue.add(new Loc(preLoc.index0+2,preLoc.index1,preLoc.times+area[preLoc.index0+2][preLoc.index1]));
queue.add(new Loc(preLoc.index0,preLoc.index1+2,preLoc.times+area[preLoc.index0][preLoc.index1+2]));
}
}
long endTime = System.currentTimeMillis();
System.out.println(endTime-startTime);
return preLoc.times;
}
static class Loc implements Comparable{
public int times;
public int index0,index1;
public Loc(int index0,int index1,int times){
this.index0=index0;
this.index1=index1;
this.times=times;
}
@Override
public int compareTo(Object obj) {
return times-((Loc)obj).times;
}
}
} /*
8
35,92,98,68,35,65,26,72
29,78,83,16,5,89,92,28
48,51,37,79,65,74,50,71
98,78,99,57,1,30,22,16
72,88,55,33,56,58,28,49
4,28,29,20,18,61,11,73
61,19,47,34,85,32,77,89
29,49,10,81,52,5,63,25
*/

问题2描述:

①若干男女生围成一圈;

②求身边女生个数最多的男生位置,个数相同去最先出现的同学;

③求男生最大的团体人数,其中最多可以包含k个女士;

举一反三

问题描述:

现有一个长度为n的序列,需要你求出最长的非增子序列,使得其长度最长,并且这个子序列是满足非增性质的。输出最长长度

输入样例:

5

1 2 1 3 4

输出样例:

4

其中有如下满足要求的子序列:

① 1 2 3 4;②1 1 3 4

奇妙的算法【7】-贪婪算法-dp的更多相关文章

  1. [算法模版]子序列DP

    [算法模版]子序列DP 如何求本质不同子序列个数? 朴素DP 复杂度为\(O(nq)\).其中\(q\)为字符集大小. \(dp[i]\)代表以第\(i\)个数结尾的本质不同子序列个数.注意,这里对于 ...

  2. [算法模板]SOS DP

    [算法模板]SOS DP 正文 SOS-DP(\(\text{Sum over Subsets}\))是用来解决这样的问题的: 其实就是子集和DP.上面每个\(F[mask]\)里面包含了\(mask ...

  3. 奇妙的算法之LCS妙解

    LCS算法妙解 LCS问题简述:最长公共子序列 一个数列 S,如果分别是两个或多个已知数列的子序列,且是所有符合此条件序列中最长的,则S 称为已知序列的最长公共子序列. LCS问题的分支:最长公共子串 ...

  4. [LeetCode] Network Delay Time 网络延迟时间——最短路算法 Bellman-Ford(DP) 和 dijkstra(本质上就是BFS的迭代变种)

    There are N network nodes, labelled 1 to N. Given times, a list of travel times as directed edges ti ...

  5. 算法笔记--数位dp

    算法笔记 这个博客写的不错:http://blog.csdn.net/wust_zzwh/article/details/52100392 数位dp的精髓是不同情况下sta变量的设置. 模板: ]; ...

  6. 算法复习——背包dp

    1.01背包 二维递推式子: 代码: ;i<=n;i++) ;x--) ][x-w[i]]+c[i],f[i-][x]); ][x]; printf("%d",f[n][m] ...

  7. 奇妙的算法【11】LeetCode-专属算法面试题汇总

    这个是LeetCode上面的编程训练专项页面,地址:https://leetcode-cn.com/explore/interview/card/top-interview-quesitons-in- ...

  8. 奇妙的算法【10】TX--有效号码、最,小耗时、最小差值、差值输出、异或结果

    昨晚刚刚写的几道算法题,难度也还行,就是全部AC有些困难,当时第一题AC.第二题AC 60%,第四题AC 40%,第五题没有时间写完了,这个应该全部AC了:其中第三题没有写出来 1,是否存在符合规范的 ...

  9. LIS(nlogn)算法描述//线性DP经典类型

    题目描述 某国为了防御敌国的导弹袭击,发展出一种导弹拦截系统.但是这种导弹拦截系统有一个缺陷:虽然它的第一发炮弹能够到达任意的高度,但是以后每一发炮弹都不能高于前一发的高度.某天,雷达捕捉到敌国的导弹 ...

随机推荐

  1. swoole的websockte例子

    服务器的环境,建议用bt.cn的一键环境 服务端: <?php /** * Created by PhpStorm. * User: Administrator * Date: 2019\5\2 ...

  2. Vue 相关开源项目库汇总

    element ★9395 - 饿了么出品的Vue2的web UI工具套件 Vux ★6835 - 基于Vue和WeUI的组件库 vueAdmin ★569 - 基于vuejs2和element的简单 ...

  3. python学习:python的常用功能示例2

    1. python 写入txt with open("douban.txt","w") as f: f.write("这是个测试!") fi ...

  4. jQuery补充之jQuery扩展/form表单提交/滚动菜单

    jQuery扩展 为了避免重复造轮子,能高效使用别人的代码,所以有了扩展. jQuery扩展有两种方式: 自执行函数方式 定义函数,并执行函数. 自执行函数: (function(jq){ jq.ex ...

  5. 普罗米修斯Prometheus监控安装

    普罗米修斯Prometheus监控安装 架构: 服务端:192.168.0.204 客户端:192.168.0.206 环境准备:所有节点安装go 语言环境 rz go1.12.linux-amd64 ...

  6. c/c++编码规范(3)--google代码规范检测工具cpplint.py

    cpplint.py是来自google开源项目风格错误检测工具.它是一个python脚本,和google开源项目风格指南一同发布.下载地址:https://github.com/google/styl ...

  7. gunicorn的log如何传递给django,由django管理

    gunicorn配置文件为gunicorn_config.py里面有日志的配置 # errorlog = '/home/admin/output/erebus/logs/gunicorn_error. ...

  8. DSP VLIB实验

    声明:引用请注明出处http://blog.csdn.net/lg1259156776/ 引言 在dsp开发中,为了节省开发时间和难度,TI将一些成熟的算法封装为模块,供开发者使用.如果能充分利用这些 ...

  9. JDK替换掉系统自带的gij编译工具

    解决办法: 在终端里面依次输入以下两句话 alternatives --install /usr/bin/java java /usr/java/jdk1.6.0_11/bin/java 300 al ...

  10. rest_framework之ModelViewSet、路由控制、序列化组件快速搭建项目雏形

    以UserInfo表登陆接口为例 ModelViewSet的用法十分简单,定义一个视图类,指定一个模型表,指定一个序列化类即可帮我们完成增删改查等功能 示例: # 视图层 from app01.MyS ...