备战蓝桥之每日一题

P1086 [NOIP2004 普及组] 花生采摘 - 洛谷 | 计算机科学教育新生态 (luogu.com.cn)

复制代码
import java.awt.Checkbox;
import java.awt.PageAttributes.OriginType;
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.io.PrintWriter;
import java.math.BigInteger;
import java.math.MathContext;
import java.security.PublicKey;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.Collections;
import java.util.Comparator;
import java.util.HashMap;
import java.util.HashSet;
import java.util.Iterator;
import java.util.LinkedList;
import java.util.PriorityQueue;
import java.util.Scanner;
import java.util.TreeMap;
import java.util.TreeSet;
public class Main {	
  public static void main(String[] args) throws NumberFormatException, IOException  {
	  Scanner scanner=new Scanner(System.in);
	 BufferedReader br1=new BufferedReader(new InputStreamReader(System.in));
	 PrintWriter pw1=new PrintWriter(System.out);
     String[] aStrings=br1.readLine().split(" ");
     int a=Integer.parseInt(aStrings[0]);
     int b=Integer.parseInt(aStrings[1]);
     int c=Integer.parseInt(aStrings[2]);
     int d,e,f,jishu;
     jishu=0;
     for(d=1;d<=a;d++) {
    	 String[] bStrings=br1.readLine().split(" ");
    	 for(e=1;e<=b;e++) {
    		 f=Integer.parseInt(bStrings[e-1]);
    		 if(f!=0) {
    			aa1[jishu]=new huasheng(f, d, e);
    			jishu++;
    		 }
    	 }
     }
     Arrays.sort(aa1,0,jishu);
    int g;
    int answer=0;
    int x1=0;
    int y1=aa1[0].y;
    int haoshi=0;
    for(g=0;g<jishu;g++) {
    	haoshi=haoshi+Math.abs(aa1[g].x-x1)+Math.abs(aa1[g].y-y1)+1+aa1[g].x;
    	
    	if(haoshi<=c) {
    		haoshi=haoshi-aa1[g].x;
    		x1=aa1[g].x;
    		y1=aa1[g].y;
    		answer=answer+aa1[g].number;
    	}
    	else {
    		break;
    	}
    }
    System.out.println(answer);
  }
public static huasheng[] aa1=new huasheng[500];
}
class huasheng implements Comparable<huasheng>{
	int number;
	int x;
	int y;
	public huasheng(int number, int x, int y) {
		super();
		this.number = number;
		this.x = x;
		this.y = y;
	}
	@Override
	public int compareTo(huasheng o) {
		// TODO Auto-generated method stub
		return o.number-this.number;
	}
	@Override
	public String toString() {
		return "huasheng [number=" + number + ", x=" + x + ", y=" + y + "]";
	}
	
}
相关推荐
Coder_Boy_3 分钟前
基于SpringAI的在线考试系统-智能考试系统-学习分析模块
java·开发语言·数据库·spring boot·ddd·tdd
2401_8948281216 分钟前
从原理到实战:随机森林算法全解析(附 Python 完整代码)
开发语言·python·算法·随机森林
cdut_suye19 分钟前
解锁函数的魔力:Python 中的多值传递、灵活参数与无名之美
java·数据库·c++·人工智能·python·机器学习·热榜
Remember_99328 分钟前
【LeetCode精选算法】前缀和专题二
算法·哈希算法·散列表
源代码•宸33 分钟前
Leetcode—509. 斐波那契数【简单】
经验分享·算法·leetcode·面试·golang·记忆化搜索·动规
逍遥德1 小时前
java Map Set List 扩容机制
java·开发语言·list
高山上有一只小老虎1 小时前
mybatisplus实现分页查询
java·spring boot·mybatis
nbsaas-boot1 小时前
基于 Java 21 ScopedValue 的多租户动态数据源完整实践
java·开发语言
2301_780669861 小时前
线程安全、线程同步(三种加锁方式)、线程池(两种创建线程池方式、线程池处理Runnable任务、线程池处理Callable任务)、并发/并行
java
liuc03171 小时前
Java项目关于不同key的读取
java·开发语言