奇妙的算法【7】-贪婪算法-dp
问题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的更多相关文章
- [算法模版]子序列DP
[算法模版]子序列DP 如何求本质不同子序列个数? 朴素DP 复杂度为\(O(nq)\).其中\(q\)为字符集大小. \(dp[i]\)代表以第\(i\)个数结尾的本质不同子序列个数.注意,这里对于 ...
- [算法模板]SOS DP
[算法模板]SOS DP 正文 SOS-DP(\(\text{Sum over Subsets}\))是用来解决这样的问题的: 其实就是子集和DP.上面每个\(F[mask]\)里面包含了\(mask ...
- 奇妙的算法之LCS妙解
LCS算法妙解 LCS问题简述:最长公共子序列 一个数列 S,如果分别是两个或多个已知数列的子序列,且是所有符合此条件序列中最长的,则S 称为已知序列的最长公共子序列. LCS问题的分支:最长公共子串 ...
- [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 ...
- 算法笔记--数位dp
算法笔记 这个博客写的不错:http://blog.csdn.net/wust_zzwh/article/details/52100392 数位dp的精髓是不同情况下sta变量的设置. 模板: ]; ...
- 算法复习——背包dp
1.01背包 二维递推式子: 代码: ;i<=n;i++) ;x--) ][x-w[i]]+c[i],f[i-][x]); ][x]; printf("%d",f[n][m] ...
- 奇妙的算法【11】LeetCode-专属算法面试题汇总
这个是LeetCode上面的编程训练专项页面,地址:https://leetcode-cn.com/explore/interview/card/top-interview-quesitons-in- ...
- 奇妙的算法【10】TX--有效号码、最,小耗时、最小差值、差值输出、异或结果
昨晚刚刚写的几道算法题,难度也还行,就是全部AC有些困难,当时第一题AC.第二题AC 60%,第四题AC 40%,第五题没有时间写完了,这个应该全部AC了:其中第三题没有写出来 1,是否存在符合规范的 ...
- LIS(nlogn)算法描述//线性DP经典类型
题目描述 某国为了防御敌国的导弹袭击,发展出一种导弹拦截系统.但是这种导弹拦截系统有一个缺陷:虽然它的第一发炮弹能够到达任意的高度,但是以后每一发炮弹都不能高于前一发的高度.某天,雷达捕捉到敌国的导弹 ...
随机推荐
- JDK目录详解
bin目录: 该目录用于存放一些可执行程序. 如javac.exe(java编译器).java.exe(java运行工具),jar.exe(打包工具)和* javadoc.exe(文档生成工具)等. ...
- 【PHP】解决数据库查询出来的中文内容显示为问号“??”
方法一:在数据库连接后执行: mysql_query('SET NAMES utf8'); 代码: $dbconn=mysql_connect("localhost", " ...
- C++线程互斥、同步
一.线程互斥 如果多个线程需要访问且可能修改同一个变量,那么需要加锁,保证同一时刻只有一个线程可以访问,这个动作即最小“原子操作” 方式1: 使用c++提供的类mutex,lock,unlock即可 ...
- jmeter 测试 websocket 接口
https://www.cnblogs.com/penghaihang/p/7724830.html(请求的亲测ok) https://www.jianshu.com/p/bb8b3e928607 h ...
- 直接用的tar压缩
将目录里的doc文件夹压缩成tar.gz tar -czf doc.tar.gz doc 解压tar.gz tar -xzvf doc.tar.gz 在不解压的情况下查看压缩包的内容: tar ...
- 【已解决】HttpWebRequest的GetResponse或GetRequestStream偶尔超时 + 总结各种超时死掉的可能和相应的解决办法
[问题] 用C#模拟网页登陆,其中去请求几个页面,会发起对应的http的请求request,其中keepAlive设置为true,提交请求后,然后会有对应的response: resp = (Http ...
- HttpRequest Get和Post调用其他页面的方法
HttpRequest Get和Post调用其他页面的方法,需要的朋友可以参考一下 //Get请求方式 private string RequestGet(string Url) { ...
- jquery图片播放插件Fancybox使用详解
今天给大家介绍的jquery图片播放插件叫Fancybox,相比LightBox来说,Fancybox相对庞大点,配置也更丰富一些,相信你会喜欢的. Fancybox的项目主页地址:http://fa ...
- cq三期备注说明
1.关于导航栏添加登陆拦截操作
- Java基础教程:IDEA单元测试
Java基础教程:IDEA单元测试 环境配置 使用idea IDE 进行单元测试,首先需要安装JUnit 插件. 安装JUnit插件步骤 File-->settings-->Plguins ...