2021-02-22

A、I love HNUCM

题目描述

  • 2020年是HNUCM本科教育60周年,为了表达对HNUCM的爱意,TC希望你能够编写一个程序帮他表达心声。👀👊✍
  • 输入一个正整数n(n<=100),输出n次“I love HNUCM.”。

输入

  • 一个正整数n(n<=100)。

输出

  • n次“I love HNUCM.”。
  • 样例输入 Copy
2
  • 样例输出 Copy
I love HNUCM.
I love HNUCM.

java代码:

package EXAM01;

import java.util.Scanner;

public class Main {

	public static void main(String[] args) {
		// TODO Auto-generated method stub
		Scanner sc = new Scanner(System.in);
		int n = sc.nextInt();
		if(n<=100){
		for(int i=0;i<n;i++)
			System.out.println("I love HNUCM.");
		}
	}

}

B、计算球体积

题目描述

  • 根据输入的半径值,计算球的体积

输入

  • 输入数据有多组,每组占一行,每行包括一个实数,表示球的半径。

输出

  • 输出对应的球的体积,对于每组输入数据,输出一行,计算结果保留三位小数。

样例输入 Copy

1
1.5

样例输出 Copy

4.189
14.137

提示

#define PI 3.1415927

java代码:

import java.util.Scanner;

public class Main {

	public static void main(String[] args) {
		
		Scanner sc = new Scanner(System.in);
		
	    double r = sc.nextDouble();//double类型
	    
	    double v = (4 * Math.PI * Math.pow(r, 3))/3;//Math.pow(r,3)表示r的三次方
	    
	    String string = String.format("%.3f", v);//规范输出保留三位小数
	    
	    System.out.println(string);
	}

}

C语言代码:

#include <stdio.h>
#define PI 3.1415927
int main(){
	double r,v;
	while(scanf("%lf",&r)!=EOF){
	v=4.0/3.0*PI*r*r*r;
	printf("%.3lf\n",v);
	}
	return 0;
}

C、成绩转换

题目描述

输入一个百分制的成绩t,将其转换成对应的等级,具体转换规则如下:
90~100为A;
80~89为B;
70~79为C;
60~69为D;
0~59为E;

输入

输入数据有多组,每组占一行,由一个整数组成。

输出

对于每组输入数据,输出一行。如果输入数据不在0~100范围内,请输出一行:“Score is error!”。

样例输入 Copy
56
67
100
123
样例输出 Copy
E
D
A
Score is error!

java代码:

package 成绩转换;

import java.util.Scanner;

public class Main {

	public static void main(String[] args) {
		// TODO Auto-generated method stub
		Scanner sc = new Scanner(System.in);
		int n;
		while(sc.hasNext()){
			n = sc.nextInt();
			if(n>=0&&n<=100){
				if(n>=0&&n<60)
					System.out.println("E");
			    if(n>=60&&n<70)
			    	System.out.println("D");
			    if(n>=70&&n<80)
			    	System.out.println("C");
			    if(n>=80&&n<90)
			    	System.out.println("B");
			    if(n>=90&&n<=100)
			    	System.out.println("A");
			}else
				System.out.println("Score is error!");
		}

	}

}

if else嵌套,个人建议用下面这种方式

import java.util.Scanner;
 
public class Main {
public static void main(String[] args) {
	Scanner input=new Scanner(System.in);
	while(input.hasNext()) {
		int n=input.nextInt();
		char s;
		if(n<0||n>100)
			System.out.println("Score is error!");
		else {
			if(n>=90)
				s='A';
			else if(n>=80)
				s='B';
			else if(n>=70)
				s='C';
			else if(n>=60)
				s='D';
			else
				s='E';
			System.out.println(s);
		}
	}
}
}

if else嵌套:C语言代码:

#include <stdio.h>
int main()
{
	int score;
	char grade;
	scanf("%d",&score);
	if (score<0)
	    printf("Score is error!");
	else
	    {
	    	if (score<=59)
	    	    printf("%c",'E');
	    	else
	    	    {
	    	    	if (score<=69)
	    	    	    printf("%c",'D');
	    	    	else
	    	    	    {
	    	    	    	if (score<=79)
	    	    	    	    printf("%c",'C');
	    	    	    	else
	    	    	    	    {
	    	    	    	    	if (score<=89)
	    	    	    	    	    printf("%c",'B');
	    	    	    	    	else
	    	    	    	    	    {
	    	    	    	    	    	if (score<=100)
	    	    	    	    	    	   printf("%c",'A');
	    	    	    	    	    	else
	    	    	    	    	    	    printf("Score is error!");
										}
								}
						}
				}
		}
	return 0;
}

switch语句-C语言:

#include<stdio.h>
int main()
{
    int score;
    while(scanf("%d",&score)!=EOF)
    {
        if(score>=0&&score<=100){
            switch(score/10)
            {
                case 10:
                case 9:printf("A\n");break;
                case 8:printf("B\n");break;
                case 7:printf("C\n");break;
                case 6:printf("D\n");break;
                default:printf("E\n");break;
            }
        }else
            printf("Score is error!");
    }
return 0;
}

D、求奇数的乘积

题目描述

  • 给你n个整数,求他们中所有奇数的乘积。

输入

  • 输入数据包含多个测试实例,每个测试实例占一行,每行的第一个数为n,表示本组数据一共有n个,接着是n个整数,你可以假设每组数据必定至少存在一个奇数。

输出

  • 输出每组数中的所有奇数的乘积,对于测试实例,输出一行。

样例输入 Copy

3 1 2 3
4 2 3 4 5

样例输出 Copy

3
15

java代码:

import java.util.Scanner;

public class Main {

	public static void main(String[] args) {
		// TODO Auto-generated method stub
		Scanner sc = new Scanner(System.in);
		int n,x,sum;
		while(sc.hasNext()){
			n = sc.nextInt();
			sum = 1;
			for(int i=0;i<n;i++){
				x = sc.nextInt();
				if(x%2!=0){
					sum*=x;
				}
				
			}
			System.out.println(sum);
		}

	}

}

C语言代码:

# include<stdio.h>
# include<math.h>
int main()
{
	int n,i,x,sum;
	while(scanf("%d",&n)!=EOF)
	{
		sum=1;
		for(i=0;i<n;i++)
		{
			scanf("%d",&x);
			if(x%2!=0)
			{
				sum*=x;
			}
		}
		printf("%d\n",sum);
	}
	return 0;
}

E、平方和和立方和

题目描述

  • 给定一段连续的整数,求出他们中所有偶数的平方和以及所有奇数的立方和

输入

  • 输入数据包含多组测试实例,每组测试实例包含一行,由两个整数m和n组成。

输出

  • 对于每组输入数据,输出一行,应包括两个整数x和y,分别表示该段连续的整数中所有偶数的平方和以及所有奇数的立方和。
    (你可以认为32位整数足以保存结果。)

样例输入 Copy

1 3
2 5

样例输出 Copy

4 28
20 152 

java代码:

import java.util.Scanner;

public class Main {

	public static void main(String[] args) {
		// TODO Auto-generated method stub
		Scanner sc = new Scanner(System.in);
		int m,n,osum,jsum;
		while(sc.hasNext()){
			m = sc.nextInt();
			n = sc.nextInt();
			osum = jsum = 0;
			if(m>n){
				int t = m;
				m = n;
				n = t;
			}
			for(int i=m;i<=n;i++){
				if(i%2==0)
					osum+=i*i;
				else
					jsum+=i*i*i;
			}
			System.out.println(osum+" "+jsum);
		}

	}

}

C语言代码:

#include<stdio.h>
int main()
{
	int  i,n,m,t,sum1,sum2;
	while(scanf("%d %d",&n,&m)!=EOF)
	{
	  sum1=sum2=0;
      if(n>m)
      {
      	t=m;
      	m=n;
      	n=t;
	  }
	  for(i=n;i<=m;i++)
	  {
	  	if(i%2==0)
		sum1+=i*i;
	  	if(i%2!=0)
	  	sum2+=i*i*i;
	  }
	  printf("%d %d\n",sum1,sum2);
	}
	return 0;
}

F、水仙花数

题目描述

  • 春天是鲜花的季节,水仙花就是其中最迷人的代表,数学上有个水仙花数,他是这样定义的:
    “水仙花数”是指一个三位数,它的各位数字的立方和等于其本身,比如:153=13+53+3^3。
    现在要求输出所有在m和n范围内的水仙花数。

输入

  • 输入数据有多组,每组占一行,包括两个整数
  • m和n(100<=m<=n<=999)。

输出

  • 对于每个测试实例,要求输出所有在给定范围内的水仙花数,就是说,输出的水仙花数必须大于等于m,并且小于等于n,如果有多个,则要求从小到大排列在一行内输出,之间用一个空格隔开;
  • 如果给定的范围内不存在水仙花数,则输出no;
  • 每个测试实例的输出占一行。

样例输入 Copy

100 120
300 380

样例输出 Copy

no
370 371

java代码:

import java.util.Scanner;

public class Main {
 
    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        int m,n;
        while(sc.hasNext()){
            m = sc.nextInt();
            n = sc.nextInt();
            int a,b,c;
            int flag = 1;
            int count = 0;
            for(int i=m; i<=n; i++){
                a = i/100;//分别取一个三位数的个位、十位、百位
                b = i/10%10;
                c = i%10;
                if(i ==Math.pow(a, 3)+Math.pow(b, 3)+Math.pow(c, 3)){
                    System.out.print(count ==0?i:" "+i);//m和n范围内有多个水仙花数时输出需空格隔开
                    flag = 0;
                    count++;
                }
            }
            if(flag == 1){//没有水仙花数
                System.out.print("no");
            }
            System.out.println();//自动换行
        }
    }
}

G、小母牛的故事

题目描述

  • 有一头母牛,它每年年初生一头小母牛。每头小母牛从第四个年头开始,每年年初也生一头小母牛。请编程实现在第n年的时候,共有多少头母牛?

输入

  • 输入数据由多个测试实例组成,每个测试实例占一行,包括一个整数n(0 n=0表示输入数据的结束,不做处理。

输出

  • 对于每个测试实例,输出在第n年的时候母牛的数量。 每个输出占一行。

样例输入 Copy

2
4
5
0

样例输出 Copy

2
4
6

java代码:

//这题是一个类斐波那契数列的题目,the key to the problem is 找到a[n]=a[n-1]+a[n-3]的规律,然后创建并调用一个函数/方法完成。
import java.util.Scanner;

public class Main {
	public static void main(String[] args) {
		Scanner sc = new Scanner(System.in);
		//做算法题时,Java输入多个int值的方法:用sc对象调用hasNext方法,当while括号里是true的时候就能不停的输入。
		while(sc.hasNext())
		{
			int n = sc.nextInt();
			if(n==0)
			{
				break;
			}
			f(n);
		}
	}
	
	public static void f(int x) {
		int[] a = new int[60];
		a[0] = 1;
		a[1] = 2;
		a[2] = 3;
		
		for(int i=3;i<x;i++)
		{
			a[i] = a[i-1]+a[i-3];
			//注意不要写成了a[x]=...
		}
		
		System.out.println(a[x-1]);
	}
}

H、XP的电灯

题目描述

  • XP最近发现一个很好玩的问题。现在有N盏电灯,序号为1到N,最开始的时候所有电灯都是关闭的。XP有一群同学,序号是(1~K),这些调皮的同学会去按电灯的开关,每个同学按开关符合一种规律。
  • 序号为1的同学会按下序号是1的倍数的灯的开关,序号是2的同学会按下序号是2的倍数的灯的开关(将关的灯打开,开的灯关闭)。
  • 现在XP有K位同学,每位同学都去操作一次,问最后有多少盏灯是亮着的?

输入

  • 每行输入两个整数,N,K(K<=N<=1000)

输出

  • 每行输入一个整数,表示打开电灯的数量。

样例输入 Copy

2 2
10 10

样例输出 Copy

1
3

C语言代码:

#include <stdio.h>
int main()
{
    int N,K,m,n=0;
    while(~scanf("%d %d",&N,&K))
    {
        n=0;
        for(int i = 1 ; i <= N ; i++)
        {
            m=0;
            for(int j = 1; j <= K; j++)
            if(i%j == 0)
                m++;//求电灯因子个数
                if(m%2 != 0)
                    n++;
        }
        printf("%d\n",n);
    }
    return 0;
}
  • 还有两个题,就在下次记录吧,废了废了😭😭😭
    有些题目是我自己不会做然后借鉴了大佬们的,所以仅仅是记录哦,不想自己忘得这么快,废了呀
  • 小白分享:

“你为什么这么强?’
因为我有不能输的理由啊!”

  • 2
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

少年游四方

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值