**数字三角形 最大路径和最小路径**

数字三角形
//求最大路径
import java.util.Scanner;

 public class Main{   
 public static void main(String[]args){
	  Scanner sc = new Scanner(System.in);
      int n = sc.nextInt();
      int[][]a = new int[n][n];
      for(int i=0 ; i<n ; i++){
          for(int j=0 ; j<=i ; j++){
              a[i][j] = sc.nextInt();
          }
      }
          for(int i=n-2;i>=0;i--) {
	   for(int j=0;j<=i;j++) {
		   a[i][j]+= Math.max(a[i+1][j], a[i+1][j+1]);
	   }
	   
   }System.out.println(a[0][0]);   
}
}

// 求最短路径
import java.util.Scanner;
public static void main(String[] args) {
Scanner sca = new Scanner(System.in);
int n = sca.nextInt();
int[][] a = new int[n][n];
int[][] b = new int[n][n];
for(int i = 0;i<n;i++){
a[i][j] = sca.nextInt();
}
}
b[0][0] = a[0][0];
for(int i = 1;i<n;i++){
for(int j = 0;j<=i;j++){
if(j0)//左侧,直接相加
b[i][j] = b[i-1][j]+a[i][j];
else if(j
i)//右侧,直接相加
b[i][j] = b[i-1][j-1]+a[i][j];
else//中间,需要用min函数求经过这条路的最短路径
b[i][j] = Math.min(b[i-1][j-1],b[i-1][j])+a[i][j];
}
}
min = b[n-1][0];
for(int i = 1;i<b[n-1].length;i++){
if(b[n-1][i]<min)
min = b[n-1][i];
}
System.out.println(min);
}
}

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值