JAVA基础编程题-入门篇

1.温度转换。
写一个将华氏温度转换成摄氏温度的程序,转换的公式是: °F = (9/5)*°C + 32其中C表示摄氏温度,F表示华氏温度。程序的输入是一个整数,表示华氏温度。输出对应的摄氏温度,也是一个整数。提示,为了把计算结果的浮点数转换成整数,需要使用下面的表达式: (int)x;其中x是要转换的那个浮点数。
代码如下:

import java.util.Scanner;

public class Main {
	public static void main(String args[]) {
	int temhua;//定义华式温度
	Scanner in = new Scanner(System.in);
	temhua = in.nextInt();
	System.out.print((int)((temhua-32)/(9/5.0)));
	}
}

2.时间转换
题目内容:
UTC是世界协调时,BJT是北京时间,UTC时间相当于BJT减去8。现在,你的程序要读入一个整数,表示BJT的时和分。整数的个位和十位表示分,百位和千位表示小时。如果小时小于10,则没有千位部分;如果小时是0,则没有百位部分;如果分小于10分,需要保留十位上的0。如1124表示11点24分,而905表示9点5分,36表示0点36分,7表示0点7分。
有效的输入范围是0到2359,即你的程序不可能从测试服务器读到0到2359以外的输入数据。
你的程序要输出这个时间对应的UTC时间,输出的格式和输入的相同,即输出一个整数,表示UTC的时和分。整数的个位和十位表示分,百位和千位表示小时。如果小时小于10,则没有千位部分;如果小时是0,则没有百位部分;如果分小于10分,需要保留十位上的0。
提醒:要小心跨日的换算。

输入格式:
一个整数,表示BJT的时和分。整数的个位和十位表示分,百位和千位表示小时。如果小时小于10,则没有千位部分;如果小时是0,则没有百位部分;如果小时不是0而且分小于10分,需要保留十位上的0。

输出格式:
一个整数,表示UTC的时和分。整数的个位和十位表示分,百位和千位表示小时。如果小时小于10,则没有千位部分;如果小时是0,则没有百位部分;如果小时不是0而且分小于10分,需要保留十位上的0。

输入样例:
933

输出样例:
133
代码如下:

import java.util.Scanner;

public class Main {
	public static void main(String args[]) {
	int BJT;
	int UTC;
	Scanner in = new Scanner(System.in);
	BJT = in.nextInt();
	if (0<=BJT&BJT<=2359)
	{int TIME1,TIME2;
	TIME1 = (BJT/100)*60+(BJT%100);
	TIME2 = Math.abs(TIME1-8*60);
	UTC = (TIME2%60)+(TIME2/60)*100;
	System.out.print(UTC);
	}
	}
}

3.信号报告
题目内容:
无线电台的RS制信号报告是由三两个部分组成的:
R(Readability) 信号可辨度即清晰度.
S(Strength) 信号强度即大小.
其中R位于报告第一位,共分5级,用1—5数字表示.
1—Unreadable
2—Barely readable, occasional words distinguishable
3—Readable with considerable difficulty
4—Readable with practically no difficulty
5—Perfectly readable
报告第二位是S,共分九个级别,用1—9中的一位数字表示
1—Faint signals, barely perceptible
2—Very weak signals
3—Weak signals
4—Fair signals
5—Fairly good signals
6—Good signals
7—Moderately strong signals
8—Strong signals
9—Extremely strong signals
现在,你的程序要读入一个信号报告的数字,然后输出对应的含义。如读到59,则输出:
Extremely strong signals, perfectly readable.
输入格式:
一个整数,信号报告。整数的十位部分表示可辨度,个位部分表示强度。输入的整数范围是[11,59]内有效的数字,这个范围外的数字不可能出现在测试数据中。

输出格式:
一句话,表示这个信号报告的意义。按照题目中的文字,先输出表示强度的文字,跟上逗号和空格,然后是表示可辨度的文字,跟上句号。注意可辨度的句子的第一个字母是小写的。注意这里的标点符号都是英文的。

输入样例:
33

输出样例:
Weak signals, readable with considerable difficulty.
代码如下:

import java.util.Scanner;

public class Main {
	public static void main(String args[]) {
	int RS;
	String a=null;
	String b=null;
	Scanner in = new Scanner(System.in);
	RS = in.nextInt();
	if (11<=RS&RS<=59)
	{switch(RS/10)
		{case 1:
			a="Unreadable";
			break;
		 case 2:
			a="Barely readable, occasional words distinguishable";
			break;
		 case 3:
			a="Readable with considerable difficulty";
			break;
		 case 4:
			a="Readable with practically no difficulty";
			break;
		 case 5:
			a="Perfectly readable";
			break;	 
		}
	  switch(RS%10) {
	     case 1:
		     b = "Faint signals, barely perceptible";
		     break;
	     case 2:
	    	 b = "Very weak signals";
	    	 break;
	     case 3:
	    	 b = "Weak signals";
	    	 break;
	     case 4:
	    	 b = "Fair signals";
	    	 break;
	     case 5:
	    	 b = "Fairly good signals";
	    	 break;
	     case 6:
	    	 b = "Good signals";
	    	 break;
	     case 7:
	    	 b = "Moderately strong signals";
	    	 break;
	     case 8:
	    	 b = "Strong signals";
	    	 break;
	     case 9:
	    	 b = "Extremely strong signals";
	    	 break;}
	  System.out.print(b+','+a);	 
	 }
	}
	}

4.奇偶个数
题目内容:
你的程序要读入一系列正整数数据,输入-1表示输入结束,-1本身不是输入的数据。程序输出读到的数据中的奇数和偶数的个数。

输入格式:
一系列正整数,整数的范围是(0,100000)。如果输入-1则表示输入结束。

输出格式:
两个整数,第一个整数表示读入数据中的奇数的个数,第二个整数表示读入数据中的偶数的个数。两个整数之间以空格分隔。

输入样例:
9 3 4 2 5 7 -1

输出样例:
4 2
代码如下:


import java.util.Scanner;

public class Main {
	public static void main(String args[]) {
	int a=0;
	int count1=0;
	int count2=0;
	Scanner in = new Scanner(System.in);
	a = in.nextInt();
	while(a!=-1) {
		if(a%2==0) {count1=count1+1;
	}
		else
		{count2=count2+1;}
		a = in.nextInt();
	}
	System.out.print(count2+" "+count1);	
	}
	}

5.数字特征值
题目内容:
对数字求特征值是常用的编码算法,奇偶特征是一种简单的特征值。对于一个整数,从个位开始对每一位数字编号,个位是1号,十位是2号,以此类推。这个整数在第n位上的数字记作x,如果x和n的奇偶性相同,则记下一个1,否则记下一个0。按照整数的顺序把对应位的表示奇偶性的0和1都记录下来,就形成了一个二进制数字。比如,对于342315,这个二进制数字就是001101。

你的程序要读入一个非负整数,整数的范围是[0,100000],然后按照上述算法计算出表示奇偶性的那个二进制数字,输出它对应的十进制值。

提示:将整数从右向左分解,数位每次加1,而二进制值每次乘2。

输入格式:
一个非负整数,整数的范围是[0,1000000]。

输出格式:
一个整数,表示计算结果。

输入样例:
342315

输出样例:
13
代码如下:

import java.util.Scanner;

public class Main {
	public static void main(String args[]) {
		int X=0;
		int count=0;
		int n=0;
		double m=0;
		Scanner in = new Scanner(System.in);
		X = in.nextInt();
		while(X!=0){
			n = X%10;
			X = X/10;
			count=count+1;
			if ((count%2==0&&n%2==0)||(count%2!=0&n%2!=0))
			{m=Math.pow(2, count-1)+m;	
		}}
		System.out.print((int)m);
	}
	}

6.素数和(我太水了,参考了:https://blog.csdn.net/dakaszeng/article/details/79059571)
题目内容:

我们认为2是第一个素数,3是第二个素数,5是第三个素数,依次类推。

现在,给定两个整数n和m,0<n<=m<=200,你的程序要计算第n个素数到第m个素数之间所有的素数的和,包括第n个素数和第m个素数。

注意,是第n个素数到第m个素数之间的所有的素数,并不是n和m之间的所有的素数。

输入格式:

两个整数,第一个表示n,第二个表示m。

输出格式:

一个整数,表示第n个素数到第m个素数之间所有的素数的和,包括第n个素数和第m个素数。

输入样例:

2 4

输出样例:

15

import java.util.Scanner;

public class Main {
	public static void main(String[] args) {
		Scanner in = new Scanner(System.in);
		int n = in.nextInt();
		int m = in.nextInt();
		int sum=0;
		int count =1;//计数器
		int x=2;//初始值
		boolean isPrime=true;//标记
		while(count<=m) {
			int i =2;
			do{
			    if(x==2) {isPrime=true;break;}//2是(特殊第一位此时count为1)素数,直接跳出do-while循环
			    else if (x%i==0) {isPrime=false;break;}//不是素数跳出直接到x++部分
			    else {isPrime=true;}
			    i++;}while(i<x);//一直验证到i==x-1,都成立是素数
				
		   if(isPrime)//是素数
		   {
			   if(n<=count&&count<=m) 
			   {sum+=x;}
			   count++;//位数加1
			   }
		   	x++;}//要是不是素数跳出do-while循环后,x得加1;是素数位数加1后,也执行
		
	System.out.print(sum);
		}}

7.念整数
题目内容:

你的程序要读入一个整数,范围是[-100000,100000]。然后,用汉语拼音将这个整数的每一位输出出来。

如输入1234,则输出:

yi er san si

注意,每个字的拼音之间有一个空格,但是最后的字后面没有空格。当遇到负数时,在输出的开头加上“fu”,如-2341输出为:

fu er san si yi

输入格式:

一个整数,范围是[-100000,100000]。

输出格式:

表示这个整数的每一位数字的汉语拼音,每一位数字的拼音之间以空格分隔,末尾没有空格。

输入样例:

-30

输出样例:

fu san ling

import java.util.Scanner;

public class Main {
	public static void main(String args[]) {
		Scanner in = new Scanner(System.in);
		int n;
		int a=0;//用来记录每次更新后数的最后一位
		String m = null;
		String b = "";//若b初始化为null,输出时也会跟上null
		int label=1;//label是输出时区别正数和负数的标记
		n = in.nextInt();
		if(n==0) {System.out.print("ling");}
		if(n<0) {label=-1;n=Math.abs(n);}//改变label值
		while(n!=0) {
			a=n%10;
			n=n/10;
		switch(a) {
		case 1:
			m= "yi";break;
		case 2:
			m= "er";break;
		case 3:
			m= "san";break;
		case 4:
			m= "si";break;
		case 5:
			m= "wu";break;
		case 6:
			m= "liu";break;
		case 7:
			m= "qi";break;
		case 8:
			m= "ba";break;
		case 9:
			m= "jiu";break;
		case 0:
			m="ling";break;
		}
		b=m+" "+b;}//注意m加到b的前面
		if(label==1) {System.out.print(b);}
		else {System.out.print("fu "+b);}//负数前面加上“fu”
		}}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值