有几题和前面的一样
1、隔行变色
题目:Excel表的格子很多,为了避免把某行的数据和相邻行混淆,可以采用隔行变色的样式。
小明设计的样式为:第1行蓝色,第2行白色,第3行蓝色,第4行白色,…
现在小明想知道,从第21行到第50行一共包含了多少个蓝色的行。
请你直接提交这个整数,千万不要填写任何多余的内容。
思路:这题简单直接奇数就好,感觉不靠谱的话也可以直接写个代码(主要是啥也不想干)
代码:
public class A {
public static void main(String[] args) {
int ans=0;
for(int i=1;i<=50;i++) {
if(i>20&&i%2==1)ans++;
}
System.out.println(ans);//15
}
}
2、立方尾不变
题目:有些数字的立方的末尾正好是该数字本身。
比如:1,4,5,6,9,24,25,…
请你计算一下,在10000以内的数字中(指该数字,并非它立方后的数值),符合这个特征的正整数一共有多少个。
请提交该整数,不要填写任何多余的内容。
思路:这题值得注意的就是要开long,因为int肯定是要爆的,开int答案是27,正确答案26
代码:
public class B {
public static void main(String[] args) {
int ans=0;
for(long i=1;i<=10000;i++) {
long s=i*i*i;
if(s%(Math.pow(10,show(i)))==i) {
System.out.println(i+" "+s);
ans++;
}
}
System.out.println(ans);
}
private static double show(long i) {
int s=0;
while(i>0) {
s++;
i/=10;
}
return s;
}
}
3、无穷分数
题目:无穷的分数,有时会趋向于固定的数字。
请计算【图1.jpg】所示的无穷分数,要求四舍五入,精确到小数点后5位,小数位不足的补0。
请填写该浮点数,不能填写任何多余的内容。
思路:直接递归前100项,答案就出来了
代码:
public class C {
static double a=1;
public static void main(String[] args) {
double x=show(1);
System.out.println(1/x);//0.58198
}
private static double show(double i) {
if(i==1000)return i+1;
return a=i+(i+1)/show(i+1);
}
}
5、格子中输出
题目: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("+");
}
对于题目中数据,应该输出:
±-----------------+
| |
| abcd1234 |
| |
| |
±-----------------+
思路:这题不是特别懂,比赛时肯定搞不出来,答案太恶心了
答案:
"%" + (width-2-s.length())/2 + "s%s%" + (width-2-s.length() - (width-2-s.length())/2) + "s";
6、奇妙的数字
题目:小明发现了一个奇妙的数字。它的平方和立方正好把0~9的10个数字每个用且只用了一次。
你能猜出这个数字是多少吗?
请填写该数字,不要填写任何多余的内容。
思路:直接暴力,找出平方和立方的数字,将每一位添加到Set里面去重,如果Set的size为10输出
代码:
import java.util.*;
public class F {
public static void main(String[] args) {
for(int i=1;i<10000;i++) {
int a=i*i;
int b=i*i*i;
Set<Integer>set=new HashSet<>();
if(show(a)+show(b)==10) {
while(a>0) {
set.add(a%10);
a/=10;
}
while(b>0) {
set.add(b%10);
b/=10;
}
if(set.size()==10)System.out.println(i);//ans=69
}
}
}
private static int show(int b) {
int s=0;
while(b>0) {
s++;
b/=10;
}
return s;
}
}
8、打印大X
题目:小明希望用星号拼凑,打印出一个大X,他要求能够控制笔画的宽度和整个字的高度。
为了便于比对空格,所有的空白位置都以句点符来代替。
要求输入两个整数m n,表示笔的宽度,X的高度。用空格分开(0<m<n, 3<n<1000, 保证n是奇数)
要求输出一个大X
例如,用户输入:
3 9
程序应该输出:
,参看【图1.jpg】)
再例如,用户输入:
4 21
程序应该输出
资源约定:
峰值内存消耗(含虚拟机) < 256M
CPU消耗 < 1000ms
请严格按要求输出,不要画蛇添足地打印类似:“请您输入…” 的多余内容。
所有代码放在同一个源文件中,调试通过后,拷贝提交该源码。
注意:不要使用package语句。不要使用jdk1.7及以上版本的特性。
注意:主类的名字必须是:Main,否则按无效代码处理。
思路:直接建一个StringBuilder的数组(感觉String可能超时),然后判断添加“*”,或“."感觉放在倒数第二题比较水,
代码:
import java.util.*;
public class H {
public static void main(String[] args) {
Scanner sc=new Scanner(System.in);
int m=sc.nextInt();
int n=sc.nextInt();
int x=n+m-1;
StringBuilder[]str=new StringBuilder[n];
for(int i=0;i<n;i++) {
str[i]=new StringBuilder();
}
for(int i=0;i<n;i++) {
for(int j=0;j<x;j++) {
if(j>=i&&j<=i+m-1)str[i].append("*");
else if(j>=n-i-1&&j<x-i)str[i].append("*");
else str[i].append(".");
}
}
for(int i=0;i<n;i++) {
System.out.println(str[i]);
}
}
}
剩下的题可以看之前写的JavaA和JavaB
蓝桥2015JavaA
蓝桥2015JavaB