Java程序之数组的应用

1、有重复的数据

在一大堆数据中找出重复的是一件经常要做的事情。现在,我们要处理许多整数,在这些整数中,可能存在重复的数据。

你要写一个程序来做这件事情,读入数据,检查是否有重复的数据。如果有,输出“YES”这三个字母;如果没有,则输出“NO”。

输入格式:

你的程序首先会读到一个正整数n,n∈[1,100000],然后是n个整数。

输出格式:

如果这些整数中存在重复的,就输出:

YES

否则,就输出:

NO

输入样例:

5
1 2 3 1 4

输出样例:

YES

源代码:

import java.util.HashSet;
import java.util.Scanner;

public class Main {
    public static void main(String[] args) {
        int arr[] = new int[100001];
        Scanner sc = new Scanner(System.in);
        int n = sc.nextInt();
        for (int i = 0; i < n; i++) {
            arr[i] = sc.nextInt();
        }
        boolean B = true;
        HashSet<Integer> set = new HashSet<>();
        for (int i = 0; i < n; i++) {
            if (set.contains(arr[i])) {
                System.out.print("YES");
                B = false;
                break;
            } else {
                set.add(arr[i]);
            }
        }
        if (B) {
            System.out.print("NO");
        }
    }
}

2、求一组数组中的平均数 

输入10个整数,输出这10个整数的的平均数,要求输出的平均数保留2位小数

###输入样例:
1 2 3 4 5 6 7 8 9 10
###输出样例:
5.50

源代码:


import java.util.Scanner;

public class Main {
    public static void main(String[] arintgs) {
        int arr[]=new int[10];
        Scanner sc=new Scanner(System.in);
        int n=10;
        for(int i=0;i<n;i++)
        {
            arr[i]=sc.nextInt();
        }
        double sum=0;
        for(int i=0;i<n;i++)
        {
            sum+=arr[i];
        }

        System.out.println(String.format("%.2f", sum/n));
    }
}

3、369寝室 

369寝室是比较特殊的寝室,因为别的寝室都住了四个人,而369寝室只有三个人。也因为这个原因,寝室里的三位同学感情特别好。但是,毕业在即,三位小伙伴马上要分别。为了在未来的某个日子可以见面,三位小伙伴有了一个约定,假设在未来的某一年,三位小伙伴的年龄的末尾正好出现3、6、9三个数,那么他们会再次相聚。

现在问题来了,假设今年三位小伙伴的年龄分别是x,y,z,那么,他们三人最早几年后可以相聚呢?

输入格式:

输入数据包括三个整数x,y,z,分别表示三位伙伴的年龄。

输出格式:

如果小伙伴最早在n年后可以相见(不包括当前这一年),那么请输出这个n;如果100年内都不存在这样的情况,输出:so sad!

输入样例:

25 22 28 

输出样例:

1

源代码:

import java.util.Scanner;

public class Main {
    public static void main(String[] args) {
        int a1, a2, a3;
        int year = 1;
        boolean flag = false;
        Scanner scanner = new Scanner(System.in);
        a1 = scanner.nextInt();
        a2 = scanner.nextInt();
        a3 = scanner.nextInt();
        for (year = 1; year < 11; year++) {
            a1 = (a1 + 1) % 10;
            a3 = (a3 + 1) % 10;
            a2 = (a2 + 1) % 10;
            if ((a1 == a2) || (a2 == a3) || (a1 == a3)) {
                flag = true;
                break;
            }
            if (((a1 == 3 || a1 == 6 || a3 == 9) && (a2 == 3 || a2 == 6 || a2 == 9) && (a3 == 3 || a3 == 6 || a3 == 9))) {
                break;
            }
        }
        if (year == 11 || flag) {
            System.out.println("so sad!");
        } else {
            System.out.println(year);
        }
    }
}

4、评委打分

班级里要搞智力竞赛啦!同学们都踊跃参加。进入最后决赛的是10个同学,随着一道道题目的出示,有时是1号选手得分,有时是5号选手得分,每次答对者得10分,最后结果如何呢?

输入格式:

第一行有十个整数,表示十位同学的初始分。第二行一个整数n,表示有n道题竞赛。
接下去有n行,每行有一个数字x,x表示本次可以加分的选手序号(每次答对者得10分)。

输出格式:

10个同学最终的得分值,每两位同学之间有一个空格。

输入样例:

10 0 0 0 10 10 0 0 0 10
3
1
10
1

输出样例:

30 0 0 0 10 10 0 0 0 20

源代码:

//package demo1;

import java.util.Scanner;

public class Main {
    public static void main(String[] args) {
        int a[]=new int[11];
        int add=0;
        Scanner scanner=new Scanner(System.in);
        for(int i=1;i<11;i++)
        {
            a[i]=scanner.nextInt();
        }
        int n=scanner.nextInt();
        for(int j=0;j<n;j++)
        {
            add=scanner.nextInt();
            a[add]+=10;
        }
        for(int z=1;z<11;z++)
        {
            System.out.print(a[z]);
            if(z<10)
            {
                System.out.print(" ");
            }
        }
    }
}

5、栈的实现及基本操作

给定一个初始为空的栈和一系列压栈、弹栈操作,请编写程序输出每次弹栈的元素。栈的元素值均为整数。

输入格式:

输入第1行为1个正整数n,表示操作个数;接下来n行,每行表示一个操作,格式为1 d或0。1 d表示将整数d压栈,0表示弹栈。n不超过20000。

输出格式:

按顺序输出每次弹栈的元素,每个元素一行。若某弹栈操作不合法(如在栈空时弹栈),则对该操作输出invalid。

输入样例:

7
1 1
1 2
0
0
0
1 3
0

输出样例:

2
1
invalid
3

源代码:

#include <stdio.h>
int main()
{
	int n;
	scanf("%d",&n);
	int a[n+1];
	int i,end,j;
	int xh,caozuo;
	end=0;
	for (i=1;i<=n;i++){
		scanf("%d",&caozuo);
		if(caozuo==0){
		  if(end==0){
		  	printf("invalid\n");
		  }	
		  else {
		  	printf("%d\n",a[end]);
		  	end--;
		  }
		}
		else {
			scanf("%d",&xh);
			end++;
			a[end]=xh;
		}
	}
	return 0;
}

6、sdut-array2-4 打印“杨辉三角“ 品中国数学史 增民族自豪感

背景介绍: 北宋人贾宪约1050年首先使用“贾宪三角”进行高次开方运算。

南宋数学家杨辉在《详解九章算法》(1261年)记载并保存了“贾宪三角”,故称杨辉三角。杨辉三角是中国数学史上的一个伟大成就。
杨辉三角,是中国古代数学的杰出研究成果之一,它把二项式系数图形化,把组合数内在的一些代数性质直观地从图形中体现出来,是一种离散型的数与形的结合。

中国南宋数学家杨辉1261年所著的《详解九章算法》一书中出现。在欧洲,帕斯卡(1623----1662)在1654年发现这一规律,所以这个表又叫做帕斯卡三角形。帕斯卡的发现比杨辉要迟393年,比贾宪迟600年。

杨辉三角数字的特点为:

(1)在三角形的首列和对角线上,数值均为1;

(2)其余数据为:每个数字等于上一行的左右两个数字之和,第n+1行的第i个数等于第n行的第i-1个数和第i个数之和,用公式表示为: C(n+1,i)=C(n,i)+C(n,i-1)。

图示为:

1.jpg

杨辉三角的应用:(a+b)的n次方,展开式中的各项系数依次对应杨辉三角的第(n+1)行中的每一项。

输入格式:

欲打印杨辉三角的行数n(1<=n<=13)。

输出格式:

每个数字占据4个字符的位置,数字左对齐,数字不足4位的右边留出空格。

输入样例:

13

输出样例:

1   
1   1   
1   2   1   
1   3   3   1   
1   4   6   4   1   
1   5   10  10  5   1   
1   6   15  20  15  6   1   
1   7   21  35  35  21  7   1   
1   8   28  56  70  56  28  8   1   
1   9   36  84  126 126 84  36  9   1   
1   10  45  120 210 252 210 120 45  10  1   
1   11  55  165 330 462 462 330 165 55  11  1   
1   12  66  220 495 792 924 792 495 220 66  12  1   

源代码:

//package demo1;

import java.util.Scanner;

public class Main {
    public static void main(String[] args) {
        Scanner sc=new Scanner(System.in);
        int NUM=14;
        int a[][]=new int[NUM][NUM];
        //a[0][0]=1;


        int n=sc.nextInt();
        for(int i=0;i<n;i++)
        {
            a[i][0]=a[i][i]=1;
        }
        for(int i=1;i<n;i++)
        {
            for(int j=1;j<i;j++)
            {
                a[i][j]=a[i-1][j]+a[i-1][j-1];
            }
        }
        for(int i=0;i<n;i++)
        {
            for(int j=0;j<=i;j++)
            {
                System.out.print(a[i][j]);
                if(a[i][j]<10)
                {
                    System.out.print("   ");
                }else if (a[i][j]<100)
                {
                    System.out.print("  ");
                }else
                {
                    System.out.print(" ");
                }
            }
            System.out.println();
        }
    }
}
  • 23
    点赞
  • 22
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

万叶学编程

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

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

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

打赏作者

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

抵扣说明:

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

余额充值