隔行变色
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,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.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依次类推最后取固定值
最后直接按照规律暴力循环即可
循环节长度
两个整数做除法,有时会产生循环小数,其循环部分称为:循环节。
比如,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方法即可。
格子中输出
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 后面的空格(总长度-两个||-字符串的长度-前面的空格的宽度)
还是有些不理解,可以多看几遍多做测验!