2014编程之美初赛第一场(java版)

来源:互联网 发布:ubuntu完全卸载wine 编辑:程序博客网 时间:2024/04/30 12:49

题目1 : 焦距

时间限制:2000ms
单点时限:1000ms
内存限制:256MB

描述

一般来说,我们采用针孔相机模型,也就是认为它用到的是小孔成像原理。

在相机坐标系下,一般来说,我们用到的单位长度,不是“米”这样的国际单位,而是相邻像素的长度。而焦距在相机坐标系中的大小,是在图像处理领域的一个非常重要的物理量。

假设我们已经根据相机参数,得到镜头的物理焦距大小(focal length),和相机胶片的宽度(CCD width),以及照片的横向分辨率(image width),则具体计算公式为:

Focal length in pixels = (image width in pixels) * (focal length on earth) / (CCD width on earth)

比如说对于Canon PowerShot S100, 带入公式得

Focal length in pixels = 1600 pixels * 5.4mm / 5.27mm = 1639.49 pixels

现在,请您写一段通用的程序,来求解焦距在相机坐标系中的大小。


输入

多组测试数据。首先是一个正整数T,表示测试数据的组数。

每组测试数据占一行,分别为

镜头的物理焦距大小(focal length on earth)

相机胶片的宽度(CCD width on earth)

照片的横向分辨率大小(image width in pixels),单位为px。

之间用一个空格分隔。


输出

每组数据输出一行,格式为“Case X: Ypx”。 X为测试数据的编号,从1开始;Y为焦距在相机坐标系中的大小(focallength in pixels),保留小数点后2位有效数字,四舍五入取整。


数据范围

对于小数据:focal length on earth和CCD width on earth单位都是毫米(mm)

对于大数据:长度单位还可能为米(m), 分米(dm), 厘米(cm), 毫米(mm), 微米(um),纳米(nm)



样例输入
25.4mm 5.27mm 1600px5400um 0.00527m 1600px
样例输出
Case 1: 1639.47pxCase 2: 1639.47px
AC/AC java代码如下:
import java.text.DecimalFormat;import java.util.Scanner;public class Main {public static void main(String[] args) {Scanner in = new Scanner(System.in);int T=in.nextInt();int i=0;double c[]=new double[3];while(T-->0){double temp;String a;char b;for(int j=0;j<2;j++){a=in.next();b=a.charAt(a.length()-2);temp=Double.parseDouble(a.substring(0, a.length()-2));if(b=='d'){c[j]=temp*100;continue;}else if(b=='c'){c[j]=temp*10;continue;}else if(b=='u'){c[j]=temp/1000;continue;}else if(b=='n'){c[j]=temp/1000000;continue;}else if(b=='m'){c[j]=temp;continue;}else c[j]=Double.parseDouble(a.substring(0, a.length()-1))*1000;}a=in.next();c[2]=Double.parseDouble(a.substring(0, a.length()-2));double res=c[0]*c[2]/c[1];DecimalFormat df = new DecimalFormat("#.00");i++;System.out.println("Case "+i+": "+df.format(res)+"px");}}}
0 0
原创粉丝点击