xtu oj环--唉

感慨:这几天都快被这个题目搞得没有耐心了,写了至少三天,但是刚刚灵光乍现,一下子明白了点,还是多读代码,多在脑子里面思考,培养耐心的能力不要浮躁

思路:想通了就很简单,由样例一可知,遍历时可以折返,那我们就想什么时候要折返才能使边权和最小呢,那就是当已经遍历过的节点的边权和小于接下来要顺时针遍历的边权和,以下是我的原始的错误的代码,因为我当时想当然的以为一定是遇见最大的边权后才会折返,但其实这么想就错了

复制代码
#include<stdio.h>
#define ll long long
int main(){
    ll T;
    scanf("%lld",&T);
    while(T--){
        int n;
        scanf("%d",&n);
        ll str[n+3];
        ll sum=0;
        ll max=0;
        for(int i=0;i<n;i++){
            scanf("%lld",&str[i]);
            sum+=str[i];
            if(str[i]>max){
                max=str[i];
            }
        }
        //不返回走(一条路走下去)
        ll min=0;
        min=(str[0]>str[n-1])?(sum-str[0]):(sum-str[n-1]);
        
        ll sum_i=0,t;
        for(int i=0;i<n;i++){
            sum_i+=str[i];
            if(str[i]==max){
                t=sum-max*2+sum_i;
                if(t<min) min=t;
                //printf("%d %d\n",min,sum_i);
            }
            
        }
        
        sum_i=0;
        for(int i=n-1;i>=0;i--){
            sum_i+=str[i];
            if(str[i]==max){
                t=sum-max*2+sum_i;
                if(t<min) min=t;
            }
            
        }
        
        
        printf("%lld\n",min);
    }
}

AC代码

复制代码
#include<stdio.h>
#define ll long long
int main(){
	ll T;
	scanf("%lld",&T);
	while(T--){
		int n;
		scanf("%d",&n);
		ll str[n+3];
		ll sum=0;
		ll max=0;
		for(int i=0;i<n;i++){
			scanf("%lld",&str[i]);
			sum+=str[i];
			if(str[i]>max){
				max=str[i];
			}
		}
		//不返回走(一条路走下去)
		ll min=0;
		min=(str[0]>str[n-1])?(sum-str[0]):(sum-str[n-1]);
		
		ll sum_i=str[0],t;
		for(int i=1;i<n;i++){
			
			if(str[i]>sum_i){
				t=sum-str[i]+sum_i;
				if(t<min) min=t;
			//	printf("%d %d\n",min,sum_i);
			}
			sum_i+=str[i];
		}
		
		sum_i=str[n-1];
		for(int i=n-2;i>=0;i--){
			if(str[i]>sum_i){
				t=sum-str[i]+sum_i;
				if(t<min) min=t;
			//	printf("%d %d\n",min,sum_i);
			}
			sum_i+=str[i];
		}
		
		
		printf("%lld\n",min);
	}
}
相关推荐
dazzle17 分钟前
机器学习算法原理与实践-入门(十一):基于PyTorch的房价预测实战
pytorch·算法·机器学习
小月球~8 小时前
天梯赛 · 并查集
数据结构·算法
仍然.8 小时前
算法题目---模拟
java·javascript·算法
潇冉沐晴10 小时前
DP——背包DP
算法·背包dp
GIOTTO情11 小时前
2026 世界互联网大会亚太峰会|AI 时代媒介投放的技术实战与算法优化
人工智能·算法
逆境不可逃11 小时前
LeetCode 热题 100 之 543. 二叉树的直径 102. 二叉树的层序遍历 108. 将有序数组转换为二叉搜索树 98. 验证二叉搜索树
算法·leetcode·职场和发展
计算机安禾11 小时前
【数据结构与算法】第19篇:树与二叉树的基础概念
c语言·开发语言·数据结构·c++·算法·visual studio code·visual studio
副露のmagic12 小时前
哈希章节 leetcode 思路&实现
算法·leetcode·哈希算法
csuzhucong12 小时前
puzzle(1037)黑白、黑白棋局
算法
XiYang-DING12 小时前
【LeetCode】链表 + 快慢指针找中间 | 2095. 删除链表的中间节点
算法·leetcode·链表