2022-6-14 真题练习

MT11 丢失的三个数
 

描述

现在有一个数组,其值为从 1 到 10000 的连续增长的数字。出于某次偶然操作,导致这个数组中丢失了某三个元素,同时顺序被打乱,现在需要你用最快的方法找出丢失的这三个元素,并且将这三个元素根据从小到大重新拼接为一个新数字,计算其除以 7 的余数。 例:丢失的元素为336 ,10 ,8435 ,得到的新数字为 103368435 ,除以七的余数为 2 。

输入描述:

输入数据为一行,包含9997个数字,空格隔开。

输出描述:

输出为一行,包含一个数字。
 1 import java.util.*;
 2 public class Main{
 3     public static void main(String[] args){
 4         Scanner sc=new Scanner(System.in);
 5         int a=0,b=0,c=0,index=1;
 6         for (int i=1;i<=9997;i++){
 7             int num=sc.nextInt();
 8             if (num!=index){
 9                 if (a==0) a=index;
10                 else if (b==0) b=index;
11                 else c=index;
12                 index++;
13             }
14             index++;
15         }
16         StringBuilder sb=new StringBuilder();
17         sb.append(a);
18         sb.append(b);
19         sb.append(c);
20         Long ans=Long.parseLong(sb.toString());
21         //System.out.print(ans);
22         System.out.print(ans%7);
23     }
24 }

思路:遍历一遍找到缺少的数字,然后拼接。

posted on 2022-06-14 11:23  阿ming  阅读(18)  评论(0编辑  收藏  举报

导航