求和、排序、判断年月日

1、求1+2!+3!+…+20!的和

public class Prog21{
	public static void main(String[] args){
		long sum = 0;
		for(int i=0;i<20;i++)
		  sum += factorial(i+1);
		System.out.println(sum);
	}
	//阶乘
	private static long factorial(int n){
		int mult = 1;
		for(int i=1;i<n+1;i++)
		  mult *= i;
		return mult;
	}
}

2、有1、2、3、4个数字,能组成多少个互不相同且无重复数字的三位数?都是多少?
程序分析:可填在百位、十位、个位的数字都是1、2、3、4。组成所有的排列后再去 掉不满足条件的排列。

public class Prog11{
	public static void main(String[] args){
		int count = 0;
		int n = 0;
		for(int i=1;i<5;i++){
			for(int j=1;j<5;j++){
				if(j==i)
				  continue;
				for(int k=1;k<5;k++){
					if(k!=i && k!=j){
						n = i*100+j*10+k;
					  System.out.print(n+" ");
					  if((++count)%5==0)
					  System.out.println();
					}
				}
			}
		}
		System.out.println();
		System.out.println("符合条件的数共:"+count+"个");
	}
}

3、输入某年某月某日,判断这一天是这一年的第几天?

import java.util.Scanner;
public class Prog14{
	public static void main(String[] args){
		Scanner scan = new Scanner(System.in).useDelimiter("\\D");//匹配非数字
		System.out.print("请输入当前日期(年-月-日):");
		int year = scan.nextInt();
		int month = scan.nextInt();
		int date = scan.nextInt();
		scan.close();
		System.out.println("今天是"+year+"年的第"+analysis(year,month,date)+"天");
	}
	//判断天数
	private static int analysis(int year, int month, int date){
		int n = 0;
		int[] month_date = new int[] {0,31,28,31,30,31,30,31,31,30,31,30};
		if((year%400)==0 || ((year%4)==0)&&((year%100)!=0))
		  month_date[2] = 29;
		for(int i=0;i<month;i++)
		  n += month_date[i];
		return n+date;
	}
	}

以下为该程序的分析:以3月5日为例,应该先把前两个月的加起来,然后再加上5天即本年的第几天,特殊情况,闰年且输入月份大于3时需考虑多加一天。

WITH 年份范围 AS ( SELECT '2022' AS 年份 UNION ALL SELECT '2023' UNION ALL SELECT '2024' UNION ALL SELECT '2025' ), 年月序列 AS ( SELECT CONVERT(VARCHAR(7), DATEADD(MONTH, num-1, CAST(年份+'-01-01' AS DATE)), 120) AS 年月 FROM 年份范围 CROSS JOIN (SELECT 1 AS num UNION SELECT 2 UNION SELECT 3 UNION SELECT 4 UNION SELECT 5 UNION SELECT 6 UNION SELECT 7 UNION SELECT 8 UNION SELECT 9 UNION SELECT 10 UNION SELECT 11 UNION SELECT 12) months ), 报废汇总 AS ( SELECT CONVERT(VARCHAR(7), CONVERT(DATE, 日期), 120) AS 年月, -- 修复:移除多余的LEFT函数 ISNULL(报废原因, '材料不良-缸体毛坯(铸造加工不良)') AS 报废原因, SUM(CONVERT(INT, 数量)) AS 数量 FROM [dbo].[V_报废不良] WHERE 生产线 = '缸体' AND 报废原因 LIKE '材料不良%' AND 产线 = 'TNGA12' AND LEFT(日期, 4) IN ('2022','2023','2024','2025') GROUP BY CONVERT(VARCHAR(7), CONVERT(DATE, 日期), 120), 报废原因 -- 修复:GROUP BY与SELECT保持一致 ), 生产实绩 AS ( SELECT LEFT(REPLACE(日期, '/', '-'), 7) AS 年月, SUM(实绩) AS 实绩 FROM 现场DB.dbo.V_加工线每月生产台数 WHERE 线别 = '缸体' AND LEFT(REPLACE(日期, '/', '-'), 4) IN ('2022','2023','2024','2025') GROUP BY LEFT(REPLACE(日期, '/', '-'), 7) ), 历史不良数据 AS ( SELECT 年月, SUM(数量) AS 数量, AVG(不良率) AS 不良率, MIN(不良率目标) AS 目标 FROM [dbo].[dwd_加工线报废返修不良] WHERE 类型 = '材料不良' AND 线组 = '缸体' AND LEFT(年月, 4) IN ('2022','2023','2024') GROUP BY 年月 ) SELECT y.年月, ISNULL(f.报废原因, '材料不良-缸体毛坯(铸造加工不良)') AS 报废原因, COALESCE(f.数量, h.数量, 0) AS 数量, p.实绩, ROUND( COALESCE( CONVERT(FLOAT, f.数量) / NULLIF(CONVERT(FLOAT, p.实绩), 0), h.不良率 / 100.0, 0 ) * 100, 4 ) AS 不良率, COALESCE(h.目标, 0.5) AS 目标 FROM 年月序列 y LEFT JOIN 报废汇总 f ON y.年月 = f.年月 LEFT JOIN 生产实绩 p ON y.年月 = p.年月 LEFT JOIN 历史不良数据 h ON y.年月 = h.年月 ORDER BY y.年月 DESC; 以上语句合并22~24年度数据平均生成22年23年24年各一组数据,生成25年度月均数据12组数据
最新发布
07-12
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值