数据最节约的备份方法 od

这篇文章介绍了使用Java解决数据备份问题的一种高效方法,通过先排序后利用双指针策略,确保在不超过500容量时优先使用大数,以达到数据备份的最节约方式。
摘要由CSDN通过智能技术生成

原文地址【华为OD题库-035】数据最节约的备份方法-java_数据最节约的备份方法java-CSDN博客

解题思路

这个题跟那个【信道分配】有类似之处,信道分配更复杂需要回溯,这个简单只需要正向遍历即可

。前提先把数据按大-》小排序,然后双指针向右移动,遵循原则,在不超过500容量情况下,尽可能的消耗大数,小数留到后面,如 300 200 100 100, 300+200=500  300+100+100=500优先用前面的组合

public static void main(String[] args) {
		Scanner sc = new Scanner(System.in);
		while(sc.hasNext()) {
			int[] nums = Arrays.stream(sc.nextLine().split(",")).mapToInt(Integer::parseInt).toArray();
			System.out.println(solution(nums, 0));
		}
	}
	public static int solution(int[] nums, int count){
		for(int i=0;i<nums.length;i++) { // 访问过的标记为-1
			if(nums[i] != -1) {// not be mark used
				int sum = nums[i];
				for(int j=i+1; j< nums.length; j++) {
					if(nums[j] != -1) {
						if(sum+ nums[j] <= 500) {
							sum += nums[j];
							nums[j] = -1; //mark
						}else {
							count +=1;
							break;
						}
					}
				}
				nums[i] = -1;
			}

		}
		return count;
	}

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值