第六届蓝桥杯JavaC组省赛真题(1)

  1. 隔行变色

Excel表的格子很多,为了避免把某行的数据和相邻行混淆,可以采用隔行变色的样式。
小明设计的样式为:第1行蓝色,第2行白色,第3行蓝色,第4行白色,....
现在小明想知道,从第21行到第50行一共包含了多少个蓝色的行。
请你直接提交这个整数,千万不要填写任何多余的内容。
package com.item.action;
public class demo11 {
    public static void main(String[] args) {
        int num=0;//计数器
        for (int i=21; i < 51; i++) {
            if (i%2==0) {
            }
            else {
                num+=1;
            }
        }
        System.out.println(num);
    }
}

  1. 立方尾不变

有些数字的立方的末尾正好是该数字本身。
比如:1,4,5,6,9,24,25,....
请你计算一下,在10000以内的数字中(指该数字,并非它立方后的数值),符合这个特征的正整数一共有多少个。
请提交该整数,不要填写任何多余的内容。
package com.item.action;

public class demo12 {
    public static void main(String[] args) {
        int num = 0;
        for (long i = 1; i <= 10000; i++) {
            long n = i * i * i;
            if (i == n % 10 || i == n % 100 || i == n % 1000 || i == n % 10000) {
                num++;
               // System.out.println(i);
            }
        }
        System.out.println(num);
    }
}

思路:直接暴力破解即可。

比对末尾相同,可以用取模法。

比如:3456 % 100 == 56

  1. 无穷分数

无穷的分数,有时会趋向于固定的数字。
请计算【图1.jpg】所示的无穷分数,要求四舍五入,精确到小数点后5位,小数位不足的补0。
请填写该浮点数,不能填写任何多余的内容。
public static void demo14(String[] args) {
    // TODO Auto-generated method stub

    double n=100;
    double sum=n+2;
    for(double i=n;i>=0;i--) {
        sum=i+(i+1)/sum;
    }
    System.out.printf("%.5f",sum);
}

思路:

刚看的时候一脸懵*

仔细看看不难看出其中的规律就是

1/1+2/2+3/3+4依次类推最后取固定值

最后直接按照规律暴力循环即可

  1. 循环节长度

两个整数做除法,有时会产生循环小数,其循环部分称为:循环节。
比如,11/13=6=>0.846153846153..... 其循环节为[846153] 共有6位。
下面的方法,可以求出循环节的长度。
请仔细阅读代码,并填写划线部分缺少的代码。
public static int f(int n, int m)
{
n = n % m;
Vector v = new Vector();

for(;;)
{
v.add(n);
n *= 10;
n = n % m;
if(n==0) return 0;
if(v.indexOf(n)>=0) _________________________________ ; //填空
}
}
注意,只能填写缺少的部分,不要重复抄写已有代码。不要填写任何多余的文字。
package com.item.action;

import java.util.Vector;

public class demo13 {
    public static int f(int n, int m)
    {
        n = n % m;    
        Vector v = new Vector();//
        
        for(;;)
        {
            v.add(n);
            n *= 10;
            n = n % m;
            if(n==0) return 0;
            if(v.indexOf(n)>=0) 
            {
                return v.size();//填空
            } ;  
        }
    }
    }

思路:此题是求出循环节的长度,题已经写出了循环条件,

而我们直接用Vector类中的size方法即可。

  1. 格子中输出

stringInGrid方法会在一个指定大小的格子中打印指定的字符串。
要求字符串在水平、垂直两个方向上都居中。
如果字符串太长,就截断。
如果不能恰好居中,可以稍稍偏左或者偏上一点。
下面的程序实现这个逻辑,请填写划线部分缺少的代码。
    public static void stringInGrid(int width, int height, String s)
    {
        if(s.length()>width-2) s = s.substring(0,width-2);
        System.out.print("+");
        for(int i=0;i<width-2;i++) System.out.print("-");
        System.out.println("+");
    
        for(int k=1; k<(height-1)/2;k++){
            System.out.print("|");
            for(int i=0;i<width-2;i++) System.out.print(" ");
            System.out.println("|");
        }
    
        System.out.print("|");
    
        String ff = ____________________________填空位置___________________________;  //填空
        System.out.print(String.format(ff,"",s,""));
              
        System.out.println("|");
    
        for(int k=(height-1)/2+1; k<height-1; k++){
            System.out.print("|");
            for(int i=0;i<width-2;i++) System.out.print(" ");
            System.out.println("|");
        }    
    
        System.out.print("+");
        for(int i=0;i<width-2;i++) System.out.print("-");
        System.out.println("+");    
    }
对应题目数据应图
public static void stringInGrid(int width, int height, String s)
    {
        if(s.length()>width-2) s = s.substring(0,width-2);
        System.out.print("+");
        for(int i=0;i<width-2;i++) System.out.print("-");
        System.out.println("+");
    
        for(int k=1; k<(height-1)/2;k++){
            System.out.print("|");
            for(int i=0;i<width-2;i++) System.out.print(" ");
            System.out.println("|");
        }
    
        System.out.print("|");
    
        String ff ="%"+(width-2-s.length())/2+"s%s%"+(width-2-s.length()-(width-2-s.length())/2)+"s" ;  //填空
        System.out.print(String.format(ff,"",s,""));
              
        System.out.println("|");
    
        for(int k=(height-1)/2+1; k<height-1; k++){
            System.out.print("|");
            for(int i=0;i<width-2;i++) System.out.print(" ");
            System.out.println("|");
        }    
    
        System.out.print("+");
        for(int i=0;i<width-2;i++) System.out.print("-");
        System.out.println("+");    
    }

思路:前面的空格(总长度-两个‘|’-中间输入的字符串)除于2 后面的空格(总长度-两个||-字符串的长度-前面的空格的宽度)

还是有些不理解,可以多看几遍多做测验!

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值