少年宫新近邮购了小机器人配件,共有3类,其中,
A类含有:8个轮子,1个传感器
B类含有: 6个轮子,3个传感器
C类含有:4个轮子,4个传感器
他们一共订购了100套机器人,收到了轮子600个,传感器280个。
根据这些信息请你计算:B类型机器人订购了多少个?
请直接提交该整数,不要填写任何多余内容。
答案:60
import java.util.*;
public class Main {
public static void main(String args[]) {
for(int i=0;i<=100;i++)
{
for(int j=0;j<=100-i;j++)
{
int a=i;
int b=j;
int c=100-i-j;
if(a*8+b*6+c*4==600 && a+b*3+c*4==280)
{
System.out.println(b);
}
}
}
}
}
2.
标题:生成回文数
所谓回文数就是左右对称的数字,比如:
585,5885,123321...
当然,单个的数字也可以算作是对称的。
小明发现了一种生成回文数的方法:
比如,取数字19,把它与自己的翻转数相加:
19 + 91 = 110,如果不是回文数,就再进行这个过程:
110 + 011 = 121 这次是回文数了。
200以内的数字中,绝大多数都可以在30步以内变成回文数,只有一个数字很特殊,就算迭代了1000次,它还是顽固地拒绝回文!
请你提交该顽固数字,不要填写任何多余的内容。
答案:196
思路:最后累加太长了用Long报错,直接try-catch输出了
import java.util.*;
public class Main {
public static boolean check(long n)
{
String s=String.valueOf(n);
int l=s.length();
if(l==1){
return true;
}
if(l%2==1)
{
int x=0;
while(x!=l-1-x)
{
if(s.charAt(x)!=s.charAt(l-1-x))
{
return false;
}
x++;
}
return true;
}
if(l%2==0)
{
int x=0;
while(x<l-1-x)
{
if(s.charAt(x)!=s.charAt(l-1-x))
{
return false;
}
x++;
}
return true;
}
return true;
}
public static long add(long n)
{
long i=n;
String str=String.valueOf(i);
str = new StringBuffer(str).reverse().toString();
long k=Long.valueOf(str);
return i+k;
}
public static void main(String args[]) {
for(int i=1;i<=200;i++)
{
long num=0;
num=add(i);
for(int j=0;j<1000;j++)
{
if(check(num))
{
break;
}
try {
num = add(num);
}
catch (Exception e){
System.out.println(i);
break;
}
}
}
}
}
3.
标题:空心菱形
小明刚刚开发了一个小程序,可以打印出任意规模的空心菱形,规模为6时,如下图:
****** ******
***** *****
**** ****
*** ***
** **
* *
** **
*** ***
**** ****
***** *****
****** ******
(如果有对齐问题,参看【图1.png】)
![](https://i-blog.csdnimg.cn/blog_migrate/8745906fef0d03ce29b348e587f6e131.png)
他一高兴,踢掉了电源,最后一次修改没有保存.....
毛病出在划线的部分。
请你帮助小明分析程序,填写划线部分缺失的代码。
public class Main
{
static String pr(int m, int n)
{
String s = "";
for(int i=0; i<n; i++) s += " ";
for(int i=0; i<m; i++) s = "*" + s + "*";
return s;
}
static void f(int n)
{
String s = pr(1,n*2-1) + "\n";
String s2 = s;
for(int i=1; i<n; i++){
s = ____________________________________; //填空位置
s2 = s + s2 + s;
}
System.out.print(s2);
}
public static void main(String[] args)
{
f(6);
}
}
注意:只填写缺少的内容,不要填写题面已有代码或说明性文字。
答案:pr(i+1, (n-i)*2-1)+"\n"
4.
标题:奇怪的数列
从X星截获一份电码,是一些数字,如下:
13
1113
3113
132113
1113122113
....
YY博士经彻夜研究,发现了规律:
第一行的数字随便是什么,以后每一行都是对上一行“读出来”
比如第2行,是对第1行的描述,意思是:1个1,1个3,所以是:1113
第3行,意思是:3个1,1个3,所以是:3113
请你编写一个程序,可以从初始数字开始,连续进行这样的变换。
数据格式:
第一行输入一个数字组成的串,不超过100位
第二行,一个数字n,表示需要你连续变换多少次,n不超过20
输出一个串,表示最后一次变换完的结果。
例如:
用户输出:
5
7
则程序应该输出:
13211321322115
资源约定:
峰值内存消耗(含虚拟机) < 512M
CPU消耗 < 1000ms
请严格按要求输出,不要画蛇添足地打印类似:“请您输入...” 的多余内容。
所有代码放在同一个源文件中,调试通过后,拷贝提交该源码。
注意:不要使用package语句。不要使用jdk1.7及以上版本的特性。
注意:主类的名字必须是:Main,否则按无效代码处理。
import java.util.*;
public class Main {
public static String analyse(String s)
{
String res=new String("");
int l=s.length();
int n=0;
while (n<l)
{
int num=1;
if(n+1<l) {
while (s.charAt(n) == s.charAt(n + 1)) {
num++;
n++;
}
}
res=res.concat(String.valueOf(num));
res=res.concat(String.valueOf(s.charAt(n)));
n++;
}
return res;
}
public static void main(String args[]) {
Scanner in=new Scanner(System.in);
String str=in.next();
int n=in.nextInt();
for(int i=0;i<n;i++)
{
str=analyse(str);
}
System.out.println(str);
}
}
5.
标题:密文搜索
福尔摩斯从X星收到一份资料,全部是小写字母组成。
他的助手提供了另一份资料:许多长度为8的密码列表。
福尔摩斯发现,这些密码是被打乱后隐藏在先前那份资料中的。
请你编写一个程序,从第一份资料中搜索可能隐藏密码的位置。要考虑密码的所有排列可能性。
数据格式:
输入第一行:一个字符串s,全部由小写字母组成,长度小于1024*1024
紧接着一行是一个整数n,表示以下有n行密码,1<=n<=1000
紧接着是n行字符串,都是小写字母组成,长度都为8
要求输出:
一个整数, 表示每行密码的所有排列在s中匹配次数的总和。
例如:
用户输入:
aaaabbbbaabbcccc
2
aaaabbbb
abcabccc
则程序应该输出:
4
这是因为:第一个密码匹配了3次,第二个密码匹配了1次,一共4次。
资源约定:
峰值内存消耗(含虚拟机) < 512M
CPU消耗 < 5000ms
请严格按要求输出,不要画蛇添足地打印类似:“请您输入...” 的多余内容。
所有代码放在同一个源文件中,调试通过后,拷贝提交该源码。
注意:不要使用package语句。不要使用jdk1.7及以上版本的特性。
注意:主类的名字必须是:Main,否则按无效代码处理。
思路:意思是在输入的字符串s中找一个长度为8的str打乱后是否与密码匹配,可以找到多个,只需要用一个数组保存字符串每个字符出现的次数即可。
import java.util.*;
public class Main {
static String str;
static String s[];
static int map[][];
static int count=0;
public static void init()
{
int l=str.length()-7;
for(int i=0;i<l;i++)
{
for(int j=0;j<8;j++)
{
int index=(s[i].charAt(j))-'a';
map[i][index]++;
}
}
}
public static void check(String code)
{
int l=str.length()-7;
int temp[]=new int[26];
for(int j=0;j<8;j++)
{
int index=(code.charAt(j))-'a';
temp[index]++;
}
for(int i=0;i<l;i++)
{
boolean flag=true;
for(int j=0;j<26;j++)
{
if(map[i][j]!=temp[j])
{
flag=false;
break;
}
}
if(flag)
{
count++;
}
}
}
public static void main(String args[]) {
Scanner in=new Scanner(System.in);
str=in.next();
s=new String[str.length()-7];
map=new int[str.length()-7][26];
for(int i=0;i<=str.length()-8;i++)
{
s[i]=str.substring(i,i+8);
}
init();
int n=in.nextInt();
for(int i=0;i<n;i++)
{
String code=in.next();
check(code);
}
System.out.println(count);
}
}
6.
标题:居民集会
蓝桥村的居民都生活在一条公路的边上,公路的长度为L,每户家庭的位置都用这户家庭到公路的起点的距离来计算,第i户家庭距起点的距离为di。
每年,蓝桥村都要举行一次集会。今年,由于村里的人口太多,村委会决定要在4个地方举行集会,其中3个位于公路中间,1个位最公路的终点。
已知每户家庭都会向着远离公路起点的方向去参加集会,参加集会的路程开销为家庭内的人数ti与距离的乘积。
给定每户家庭的位置di和人数ti,请为村委会寻找最好的集会举办地:p1, p2, p3, p4 (p1<=p2<=p3<=p4=L),使得村内所有人的路程开销和最小。
【输入格式】
输入的第一行包含两个整数n, L,分别表示蓝桥村的家庭数和公路长度。
接下来n行,每行两个整数di, ti,分别表示第i户家庭距离公路起点的距离和家庭中的人数。
【输出格式】
输出一行,包含一个整数,表示村内所有人路程的开销和。
【样例输入】
6 10
1 3
2 2
4 5
5 20
6 5
8 7
【样例输出】
18
【样例说明】
在距起点2, 5, 8, 10这4个地方集会,6个家庭需要的走的距离分别为1, 0, 1, 0, 2, 0,总的路程开销为1*3+0*2+1*5+0*20+2*5+0*7=18。
【数据规模与约定】
对于10%的评测数据,1<=n<=300。
对于30%的评测数据,1<=n<=2000,1<=L<=10000,0<=di<=L,di<=di+1,0<=ti<=20。
对于100%的评测数据,1<=n<=100000,1<=L<=1000000,0<=di<=L,di<=di+1,0<=ti<=1000000。
资源约定:
峰值内存消耗(含虚拟机) < 512M
CPU消耗 < 8000ms
请严格按要求输出,不要画蛇添足地打印类似:“请您输入...” 的多余内容。
所有代码放在同一个源文件中,调试通过后,拷贝提交该源码。
注意:不要使用package语句。不要使用jdk1.7及以上版本的特性。
注意:主类的名字必须是:Main,否则按无效代码处理。
思路:暂时只想到暴力,p1,p2,p3必取在某三个家庭的位置,家庭数大了估计会超时。
import java.util.*;
public class Main {
static int n,L;
static int pos[];
static int w[];
public static int choose(int p1,int p2,int p3)
{
int d=0;
for(int i=0;i<n;i++)
{
if(i<=p1)
{
d+=(pos[p1]-pos[i])*w[i];
continue;
}
if(i<=p2)
{
d+=(pos[p2]-pos[i])*w[i];
continue;
}
if(i<=p3)
{
d+=(pos[p3]-pos[i])*w[i];
continue;
}
if(i<=L)
{
d+=(L-pos[i])*w[i];
continue;
}
}
return d;
}
public static void main(String args[]) {
Scanner in=new Scanner(System.in);
n=in.nextInt();
L=in.nextInt();
pos=new int[n];
w=new int[n];
for(int i=0;i<n;i++)
{
pos[i]=in.nextInt();
w[i]=in.nextInt();
}
int res=99999999;
for(int i=0;i<n-2;i++)
{
for(int j=i+1;j<n-1;j++)
{
for(int k=j+1;k<n;k++)
{
int d;
d=choose(i,j,k);
if(d<res)
{
res=d;
}
}
}
}
System.out.println(res);
}
}