蓝桥杯之高斯日记java快速解法

题目标题: 高斯日记

    大数学家高斯有个好习惯:无论如何都要记日记。


    他的日记有个与众不同的地方,他从不注明年月日,而是用一个整数代替,比如:4210

    后来人们知道,那个整数就是日期,它表示那一天是高斯出生后的第几天。这或许也是个好习惯,

    它时时刻刻提醒着主人:日子又过去一天,还有多少时光可以用于浪费呢?

    高斯出生于:1777年4月30日。
    
    在高斯发现的一个重要定理的日记上标注着:5343,因此可算出那天是:1791年12月15日。

    高斯获得博士学位的那天日记上标着:8113   

    请你算出高斯获得博士学位的年月日。

提交答案的格式是:yyyy-mm-dd, 例如:1980-03-21

请严格按照格式,通过浏览器提交答案。

注意:只提交这个日期,不要写其它附加内容,比如:说明性的文字。


思路:首先介绍java的Calendar类:

首先初始化:Calendar calendar = Calendar.getInstance();

之后这个calendar就会被初始化成当前的日期

取的化也很方便,calendar.get(Calendar.YEAR) 表示取年,同理

calendar.get(Calendar.MONTH) 表示取月份,注意月份是从0月开始算的,显示2实际上是3月

calendar.get(Calendar.DATE)表示几号

想算一个日期的后XX天和XX月也相当方便。

比如想算当前日期后100天的日子

calendar.set(2018,2,27+100)

他就能自动变成100天后的日期,不需要管闰年大小月之类

附上高斯日记问题简单解法代码:

    
Calendar calendar = Calendar.getInstance();
		calendar.set(1777,03, 30+5343);
		System.out.println(calendar.get(Calendar.YEAR));
		System.out.println(calendar.get(Calendar.MONTH));
		System.out.println(calendar.get(Calendar.DAY_OF_MONTH)-1);


  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是Java中使用高斯模糊算法对Bitmap进行处理的代码示例: ```java public static Bitmap gaussianBlur(Bitmap src, float radius) { if (src == null) { return null; } int width = src.getWidth(); int height = src.getHeight(); int[] pixels = new int[width * height]; src.getPixels(pixels, 0, width, 0, 0, width, height); int[] resultPixels = new int[width * height]; System.arraycopy(pixels, 0, resultPixels, 0, pixels.length); int[] alpha = new int[256]; for (int i = 0; i < 256; i++) { alpha[i] = (int) (Math.exp(-((float) i * i) / (2 * radius * radius)) / (Math.sqrt(2 * Math.PI) * radius) * 255); } int[] box = new int[(int) (2 * radius)]; int boxWidth = (int) (radius / Math.sqrt(2 * Math.log(255))); int boxSize = boxWidth * 2 + 1; for (int i = 0; i < boxSize; i++) { box[i] = alpha[(int) (255 * i / boxSize)]; } for (int y = 0; y < height; y++) { for (int x = 0; x < width; x++) { int red = 0; int green = 0; int blue = 0; int alphaSum = 0; for (int i = -boxWidth; i <= boxWidth; i++) { int pixelIndex = x + clamp(i, 0, width - 1) + y * width; int pixel = pixels[pixelIndex]; int coeff = box[Math.abs(i)]; red += Color.red(pixel) * coeff; green += Color.green(pixel) * coeff; blue += Color.blue(pixel) * coeff; alphaSum += Color.alpha(pixel) * coeff; } int resultPixelIndex = x + y * width; resultPixels[resultPixelIndex] = Color.argb(alphaSum >> 8, red >> 8, green >> 8, blue >> 8); } } Bitmap result = Bitmap.createBitmap(width, height, Bitmap.Config.ARGB_8888); result.setPixels(resultPixels, 0, width, 0, 0, width, height); return result; } private static int clamp(int value, int min, int max) { return Math.max(min, Math.min(value, max)); } ``` 其中,使用了以下公式计算高斯函数的系数: ``` alpha[i] = exp(-i^2 / (2 * radius^2)) / (sqrt(2 * PI) * radius) * 255 ``` 对于每个像素点,都会计算出一个以该像素点为中心的正方形框,框内像素点的加权平均值作为该像素点的值。每个像素点的加权系数使用上述公式计算得到。在处理边缘像素点时,使用了clamp函数将超出边界的像素点坐标限制在合法范围内。最后,将处理后的像素数组生成为一个新的Bitmap并返回。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值