1、ACS
题目
本题总分:5 分
【问题描述】已知大写字母 A 的 ASCII 码为 65,请问大写字母 L 的 ASCII 码是多少?
76
解题思路
通过char强转int
代码实现
package 轮1省赛11至13;
public class 第12届题目1 {
public static void main(String[] args) {
// TODO Auto-generated method stub
char a='L';
System.out.println((int)Sa);
}
}
2、空间
题目
本题总分:5 分
【问题描述】
小蓝准备用 256MB 的内存空间开一个数组,数组的每个元素都是 32 位二进制整数,如果不考虑程序占用的空间和维护内存需要的辅助空间,请问256MB 的空间可以存储多少个 32 位二进制整数?
解题思路
1bit可以存储一个二进制0/1;32位二进制,占用32bit
计算有多少bit,/32
1MB=1024KB
1KB=1024Byte
1Byte=8bit
代码实现
package 轮1省赛11至13;
public class 第12届题目2 {
public static void main(String[] args) {
// TODO Auto-generated method stub
long Mb=256;
long Kb=1024;
long b=1024;
long Byte=8;
System.out.println(Mb*Kb*b*Byte/32);
}
}
3、卡片
题目
本题总分:10 分
【问题描述】
小蓝有很多数字卡片,每张卡片上都是数字 0 到 9。
小蓝准备用这些卡片来拼一些数,他想从 1 开始拼出正整数,每拼一个,就保存起来,卡片就不能用来拼其它数了。
小蓝想知道自己能从 1 拼到多少。
例如,当小蓝有 30 张卡片,其中 0 到 9 各 3 张,则小蓝可以拼出 1 到 10,
但是拼 11 时卡片 1 已经只有一张了,不够拼出 11。
现在小蓝手里有 0 到 9 的卡片各 2021 张,共 20210 张,请问小蓝可以从 1
拼到多少?
提示:建议使用计算机编程解决问题。
解题思路
经过简单分析可知
数字 1 一定是最先消耗完的,所以我们只计数1就可以
通过循环遍历所有数,
转换为字符串类型,从字符串里寻找1计数,
没有想到对应函数,转换通过删除,比对前后长度获取1的个数
没有删除指定字符函数,通过replace把1替换为空,做新字符窜,
num=原。length-新.length
1数量-=num
归零结束
代码实现
package 轮1省赛11至13;
public class 第12届题目3 {
public static void main(String[] args) {
// TODO Auto-generated method stub
int a1 = 2021;
for (int i = 0; i < 20210; i++) {
String str = i+"";
String newStr = str.replace("1", "");
int num = str.length()-newStr.length();
a1 = a1-num;
if (a1<=0) {
System.out.println(i+);
break;
}
}
}
}