蓝桥杯-学校的第一次练习题

1001.比酒量

题干

Description
有一群海盗(不多于20人),在船上比拼酒量。过程如下:打开一瓶酒,所有在场的人平分喝下,有几个人倒下了。再打开一瓶酒平分,又有倒下的,再次重复...... 直到开了第4瓶酒,坐着的已经所剩无几,海盗船长也在其中。当第4瓶酒平分喝下后,大家都倒下了。

等船长醒来,发现海盗船搁浅了。他在航海日志中写到:“......昨天,我正好喝了一瓶.......奉劝大家,开船不喝酒,喝酒别开船......”

请你根据这些信息,推断开始有多少人,每一轮喝下来还剩多少人。

如果有多个可能的答案,请列出所有答案,每个答案占一行。

格式是:人数,人数,...

    例如,有一种可能是:20,5,4,2,0

Input
无输入
Output
例如,有一种可能是:20,5,4,2,0

Sample Input
无输入
Sample Output
18,9,3,2,0
15,10,3,2,0
20,5,4,2,0
12,6,4,2,0
SubmitStatistic

代码

package teas1;

public class T1 {

    public static void main(String[] args) {
        for (int i = 20; i > 6; i--) {
            for (int j = i-1; j > 3&&i>j; j--) {
                for (int k = j-1; k > 2&&j>k ; k--) {
                    for (int l = k-1; l > 1&&k>l; l--) {
                        if (j*k*l+i*k*l+i*j*l+i*j*k==i*j*k*l) {
                            System.out.println(i+","+j+","+k+","+l+",0");
                        }
                    }
                }
            }
        }
    }
}

1002.扑克牌移动

题干

Description
下面代码模拟了一套扑克牌(初始排序A~K,共13张)的操作过程。

操作过程是:
手里拿着这套扑克牌,从前面拿一张放在后面,再从前面拿一张放桌子上,再从前面拿一张放在后面,....
如此循环操作,直到剩下最后一张牌也放在桌子上。

下面代码的目的就是为了求出最后桌上的牌的顺序。

初始的排列如果是A,2,3...K,则最后桌上的顺序为:
[2, 4, 6, 8, 10, Q, A, 5, 9, K, 7, 3, J]

import java.util.*;
public class A23
{
 public static List moveCard(List src)
 {
  if(src==null) return null;

  List dst = new Vector();
  for(;;)
  {
   if(__________________) break;  // 填空
   src.add(src.remove(0));
   dst.add(__________________);  // 填空
  }

  return dst;
 }

 public static void main(String[] args)
 {
  List a = new Vector();
  a.addAll(Arrays.asList("A","2","3","4","5","6","7","8","9","10","J","Q","K"));
  System.out.println(moveCard(a));
 }
}

请分析代码逻辑,并推测划线处的代码。

Input
将程序完整输入,并将空格处填写完整运行

Output
[2,4,6,8,10,Q,A,5,9,K,7,3,J]
Sample Input
无
Sample Output
[2,4,6,8,10,Q,A,5,9,K,7,3,J]

代码

package teas1;
import java.util.*;

public class T2 {
     public static List moveCard(List src)
     {
      if(src==null) return null;

      List dst = new Vector();
      for(;;)
      {
       if(dst.size()==13) break;  // 填空
       src.add(src.remove(0));
       dst.add(src.remove(0));  // 填空
      }
      return dst;
     }

     public static void main(String[] args)
     {
          List a = new Vector();
          a.addAll(Arrays.asList("A","2","3","4","5","6","7","8","9","10","J","Q","K"));
          System.out.println(moveCard(a));
     }
    }

1003.括号问题

题干

Description

下面的代码用于判断一个串中的括号是否匹配
所谓匹配是指不同类型的括号必须左右呼应,可以相互包含,但不能交叉

例如:
..(..[..]..)..  是允许的
..(...[...)....].... 是禁止的
对于 main 方法中的测试用例,应该输出:
false
true
false
false

import java.util.*;
public class A22
{
 public static boolean isGoodBracket(String s)
 {
  Stack<Character> a = new Stack<Character>();

  for(int i=0; i<s.length(); i++)
  {
   char c = s.charAt(i);
   if(c==‘(‘) a.push(‘)‘);
   if(c==‘[‘) a.push(‘]‘);
   if(c==‘{‘) a.push(‘}‘);

   if(c==‘)‘ || c==‘]‘ || c==‘}‘)
   {
    if(____________________) return false;    // 填空
    if(a.pop() != c) return false;
   }
  }

  if(___________________) return false;  // 填空

  return true;
 }

 public static void main(String[] args)
 {
  System.out.println( isGoodBracket("...(..[.)..].{.(..).}..."));
  System.out.println( isGoodBracket("...(..[...].(.).){.(..).}..."));
  System.out.println( isGoodBracket(".....[...].(.).){.(..).}..."));
  System.out.println( isGoodBracket("...(..[...].(.).){.(..)...."));
 }
}

请分析代码逻辑,并推测划线处的代码。

Input
将程序源码完整输入,并填充下划线中的内容。
Output
false
true
false
false
Sample Input
无输入
Sample Output
false
true
false
false

代码

package teas1;

import java.util.*;
public class T3
{
 public static boolean isGoodBracket(String s)
 {
  Stack<Character> a = new Stack<Character>();

  for(int i=0; i<s.length(); i++)
  {
   char c = s.charAt(i);
   if(c==‘(‘) a.push(‘)‘);
   if(c==‘[‘) a.push(‘]‘);
   if(c==‘{‘) a.push(‘}‘);

   if(c==‘)‘ || c==‘]‘ || c==‘}‘)
   {
    if(a.size()==0) return false;    // 填空
    if(a.pop() != c) return false;
   }
  }

  if(a.size()!=0) return false;  // 填空

  return true;
 }

 public static void main(String[] args)
 {
     Scanner scanner=new Scanner(System.in);
     String string=scanner.nextLine();
     System.out.println(isGoodBracket(string));
 }
}

1004.密码发生器

题干

Description

在对银行账户等重要权限设置密码的时候,我们常常遇到这样的烦恼:如果为了好记用生日吧,容易被破解,不安全;如果设置不好记的密码,又担心自己也会忘记;如果写在纸上,担心纸张被别人发现或弄丢了...

这个程序的任务就是把一串拼音字母转换为6位数字(密码)。我们可以使用任何好记的拼音串(比如名字,王喜明,就写:wangximing)作为输入,程序输出6位数字。

变换的过程如下:

第一步. 把字符串6个一组折叠起来,比如wangximing则变为:
wangxi

ming

第二步. 把所有垂直在同一个位置的字符的ascii码值相加,得出6个数字,如上面的例子,则得出:
228 202 220 206 120 105

 第三步. 再把每个数字“缩位”处理:就是把每个位的数字相加,得出的数字如果不是一位数字,就再缩位,直到变成一位数字为止。例如: 228 => 2+2+8=12 => 1+2=3

上面的数字缩位后变为:344836, 这就是程序最终的输出结果!

要求程序从标准输入接收数据,在标准输出上输出结果。

输入格式为:第一行是一个整数n(<100),表示下边有多少输入行,接下来是n行字符串,就是等待变换的字符串。
输出格式为:n行变换后的6位密码。

Input
例如,输入:
5
zhangfeng
wangximing
jiujingfazi
woaibeijingtiananmen
haohaoxuexi
Output
则输出:
772243
344836
297332
716652
875843
Sample Input
6
abcdefg
kelindun
yazhouxiong
woainisaibeidexue
tiaotiaodalutongluoma
xyz
Sample Output
289123
849621
748779
137563
848586
345000
Hint
注意:

请仔细调试!您的程序只有能运行出正确结果的时候才有机会得分!
在评卷时使用的输入数据与试卷中给出的实例数据可能是不同的。

代码

package teas1;

import java.util.Scanner;

public class T4 {

    /**
     * @param args
     */
    public static void main(String[] args) {
        // TODO 自动生成的方法存根

        Scanner scanner=new Scanner(System.in);
        int co=Integer.parseInt(scanner.nextLine());

        String[] reString=new String[co];
        for (int i = 0; i < co; i++) {
            reString[i]=getMima(scanner.nextLine());
        }
        //打印值
        for (int i = 0; i < reString.length; i++) {
            System.out.println(reString[i]);

        }
    }

    private static String getMima(String nextLine) {

        int[] gewei=new int[6];
        //分別取每位的值
        int conut=0;
        for (int i = 0; i < nextLine.length(); i++) {
             gewei[conut]=gewei[conut] + (int)nextLine.charAt(i);
             conut++;
             conut=conut>5?0:conut;
        }

        //简化成一位数
        String reString="";
        for (int i = 0; i < gewei.length; i++) {
            String str=gewei[i]+"";
            while(gewei[i]>9) {
                int a=0;
                for (int j = 0; j < str.length(); j++) {
                    a =a+ Integer.parseInt(str.charAt(j)+"");
                }
                gewei[i]=a;
                str=gewei[i]+"";
            }
            reString=reString+gewei[i]+"";
        }
        return reString;
    }
}

1005.警察智力训练

题干

Description

匪警请拨110,即使手机欠费也可拨通!

为了保障社会秩序,保护人民群众生命财产安全,警察叔叔需要与罪犯斗智斗勇,因而需要经常性地进行体力训练和智力训练!

某批警察叔叔正在进行智力训练:

1 2 3 4 5 6 7 8 9 = 110;

请看上边的算式,为了使等式成立,需要在数字间填入加号或者减号(可以不填,但不能填入其它符号)。之间没有填入符号的数字组合成一个数,例如:12+34+56+7-8+9 就是一种合格的填法;123+4+5+67-89 是另一个可能的答案。

请你利用计算机的优势,帮助警察叔叔快速找到所有答案。

每个答案占一行。形如:

12+34+56+7-8+9
123+4+5+67-89
......

Input
无输入
Output
1+2+34+5+67-8+9
1+234-56-78+9
1-2+3+45-6+78-9
12+3+45+67-8-9
12+34+56+7-8+9
12-3+4-5+6+7+89
123+4+5+67-89
123+4-5-6-7-8+9
123-4+5-6-7+8-9
123-4-5+6+7-8-9
Sample Input
无输入
Sample Output
1+2+34+5+67-8+9
1+234-56-78+9
1-2+3+45-6+78-9
12+3+45+67-8-9
12+34+56+7-8+9
12-3+4-5+6+7+89
123+4+5+67-89
123+4-5-6-7-8+9
123-4+5-6-7+8-9
123-4-5+6+7-8-9

代码

package teas1;

import java.util.ArrayList;

public class T5 {

    /**
     * @param args
     */
    public static void main(String[] args) {
        // TODO 自动生成的方法存根
        char[] arr={‘1‘,‘2‘,‘3‘,‘4‘,‘5‘,‘6‘,‘7‘,‘8‘,‘9‘};
        char[] fuhao={‘ ‘,‘+‘,‘-‘};

        for(char x1:fuhao){
            for(char x2:fuhao){
                for(char x3:fuhao){
                    for(char x4:fuhao){
                        for(char x5:fuhao){
                            for(char x6:fuhao){
                                for(char x7:fuhao){
                                    for(char x8:fuhao){

                                        char[] fu={x1,x2,x3,x4,x5,x6,x7,x8};
                                        String string="";
                                        String re="";

                                        ArrayList<String> cha=new ArrayList<>();
                                        for (int i = 0; i < fu.length; i++) {
                                            if (!(fu[i]+"").equals(" ")) {
                                                string =string+arr[i]+‘,‘;
                                                re=re+arr[i]+fu[i];
                                                cha.add(fu[i]+"");
                                            }else{
                                                string =string+arr[i];
                                                re =re+arr[i];
                                            }
                                        }

                                        string+=arr[8];
                                        re+=arr[8];
                                        String[] strArr=string.split(",");

                                        int sum=Integer.parseInt(strArr[0]);

                                        for (int i = 0; i < strArr.length-1; i++) {
                                            if (cha.get(i).equals("+")) {
                                                sum+=Integer.parseInt(strArr[i+1]);
                                            }else {
                                                sum-=Integer.parseInt(strArr[i+1]);
                                            }
                                        }
                                        if(sum==110)
                                        System.out.println(re);
                                    }
                                }
                            }
                        }
                    }
                }
            }
        }
    }
}
时间: 2024-10-26 06:37:30

蓝桥杯-学校的第一次练习题的相关文章

第五届蓝桥杯练习题 - 入门练习Java解题代码

>>入门训练 圆的面积 时间限制:1.0s   内存限制:256.0MB 锦囊1 锦囊2 锦囊3 问题描述 给定圆的半径r,求圆的面积. 输入格式 输入包含一个整数r,表示圆的半径. 输出格式 输出一行,包含一个实数,四舍五入保留小数点后7位,表示圆的面积. 说明:在本题中,输入是一个整数,但是输出是一个实数. 对于实数输出的问题,请一定看清楚实数输出的要求,比如本题中要求保留小数点后7位,则你的程序必须严格的输出7位小数,输出过多或者过少的小数位数都是不行的,都会被认为错误. 实数输出的问题

第八届蓝桥杯省赛题解

一直以来,自己的科技类竞赛实在太少了,确实是自己的问题,从大学没有对自己有一个明确的规划,现在再回过头去恶补很多的知识点.悔当初,甚至怀疑自己,却已经来不及,最近因为某些人某些事让自己心情变得十分差,把自己弄得狼狈不堪. 今年是第一次参加蓝桥杯比赛,原本寒假就打算好好复习的,一直没有静下心来准备,正式做题是在比赛前3天.校区是在绵阳师范墨家小区,还以为头一天就要赶过去,后面接到学院老师的电话说一起跟着大部队过去,于是就在早上6点起来,看了会算法,吃早餐后就随着校车去了. 这次去参赛的都是比较厉害

2015第六届蓝桥杯全国软件大赛省赛(预赛)总结

这是我上大学以来第一次自发的写总结,这也许意味着我对大学的看法和接下来的大学生活都将有所改变吧.首先说说引导我写这篇总结的"人物"吧,RUI,从大一开始便是同学,直到大三成为了舍友.他的成绩一直很好,如果没记错的话,大一专业第一名,大二好像也是第一第二的,总之在班里一直名列前茅,在学习成绩里边,最让我羡慕的就是他的英语了,四级和六级都是一次过,并且,六级考了500多分(具体多少记不清了),呃...除了学习成绩好之外,专业能力更是没的说,在大一就加入了学院里的ACM实验室,编程能力那也是

记2014“蓝桥杯全国软件大赛&quot;决赛北京之行

5月29,30日 终于到了这一天.晚上有数据结构课,10点多的火车,我们就没有去上课,下午在宿舍里收拾东西,晚上8点左右从南校出发,9点半多到达火车站和老师学长学姐们会和. 第一次去北京,第一次买的卧铺,真的很兴奋.对这次北京之行满满的都是期待.卧铺,躺在上面很舒服,因为第一次,不知道还需要换票,就把票放在包里了,找了一会才找到,看来还是得把票随身带着.卧铺晚上熄灯,我看了一部电影,然后就睡着了,一觉睡到五点多.上午看了看模板,这次蓝桥杯决赛说实话没有怎么认真的准备,做的题也比较少.把一些小的知

天梯赛+蓝桥杯 总结

3月31天梯赛,4.1蓝桥杯.两个比赛接着好近,而且都是第一次参赛,有点小紧张的. 天梯赛个人打的一般般,凉凉了. 蓝桥杯的话就更凉了,感觉比以前的题目难多了. 先说天梯赛吧,比赛时好多人都出现了账号名字与真实姓名不同的情况下,或者登入不进去,还好我的登入成功了.由于这个问题比赛推迟了十分钟,还好没推迟很久. 进去后首先就看了第一题20分的,看了三分钟左右,还没有看懂题意,心理就感觉要凉了,第一题都还没看懂.之后才知道第一题是L1中最难的.... 还好卡了就没有继续钻牛角尖了,直接返回看分值最小

关于这两天的比赛——PTA与蓝桥杯

这几天分别在中南大学与长沙理工大学打了两场比赛--天梯赛与蓝桥杯,好吧,我作为菜鸡见了两次世面,这不比不知道,一比吓一跳,同为17级,我们学校与其他学校的差距原来这么大. "如果对于冠军没有要求,去比赛就像旅游"--某心态已崩的HUCM队员. 我现在回想一下比赛的经历,有这么几点: 1.第一次参加,对于各项事务都是一脑壳问号,对于赛点不熟悉也是我发挥不好的原因:(本来就菜,这下子更菜了) 2.在做题时,我的策略也有一些问题,简单问题想复杂了,复杂问题......想简单了,结果就....

第三届蓝桥杯 c/c++真题

第三届蓝桥杯真题 c/c++ 以下题目我自己也并不是所有的题目都是一次性就能做对或是有结题思路的.有些题目也是经过查证网上相关的资料或是参考了别人的代码和解题思路才做出来的.总的来看,这份题目考了很多循环的只是,还有模拟,动态规划的只是. 其中做题过程中,也有了一些新的体会.起初做代码填空题的时候我没办法知道自己做的是对还是错,就跑到网上查答案,后来发现,题目已经给出了代码,起始我们可以自己加上头文件,然后把空缺的代码加上进行调试的,这样就可以验证自己补充的代码是否正确了. 此外在进行调试的时候

第四届蓝桥杯 c/c++真题

第四届蓝桥杯 c/c++真题 <1>高斯日记 问题 大数学家高斯有个好习惯:无论如何都要记日记. 他的日记有个与众不同的地方,他从不注明年月日,而是用一个整数代替,比如:4210 后来人们知道,那个整数就是日期,它表示那一天是高斯出生后的第几天.这或许也是个好习惯,它时时刻刻提醒着主人:日子又过去一天,还有多少时光可以用于浪费呢? 高斯出生于:1777年4月30日. 在高斯发现的一个重要定理的日记上标注着:5343,因此可算出那天是:1791年12月15日. 高斯获得博士学位的那天日记上标着:

算法笔记_076:蓝桥杯练习 结点选择(Java)

目录 1 问题描述 2 解决方案   1 问题描述 问题描述 有一棵 n 个节点的树,树上每个节点都有一个正整数权值.如果一个点被选择了,那么在树上和它相邻的点都不能被选择.求选出的点的权值和最大是多少? 输入格式 第一行包含一个整数 n . 接下来的一行包含 n 个正整数,第 i 个正整数代表点 i 的权值. 接下来一共 n-1 行,每行描述树上的一条边. 输出格式 输出一个整数,代表选出的点的权值和的最大值. 样例输入 51 2 3 4 51 21 32 42 5 样例输出 12 样例说明