2019年全国高校计算机能力挑战赛初赛java语言解答
1:题目1
16.某星球存在两种生物,A种生物有1个头6条腿,B种生物有3个头4条腿。来自地球的太空船刚刚在该星球降落,突然发现一大群这两种生物组成的队伍,由于时间紧,只数了头的数量和腿的数量,请帮助宇航员分析A、B两种生物各有多少个。
输入说明:头的数量L腿的数量Z,(L,Z<=100000);输出说明:A生物的数量B生物的数量(两个整数用一个空格隔开);输入样例:10 32输出样例:42
公式:
//头 x 腿 y
// x+6y=M
//3x+4y=N
// 3*m-1*n=3*6-1*4 ==y
// 4*y-N/3=x
import java.util.Scanner;
public class Main1 {
public static void main(String[] args) {
Scanner input = new Scanner(System.in);
int m,n,x,y;
m=input.nextInt();
n=input.nextInt();
y=(6*m-1*n)/(3*6-4*1);
x=(n-4*y)/6;
System.out.println(x+" "+y);
input.close();
}
}
2:题目2
17.对于给出的长度为N(N<1000)的正整数数组,满足连续3个元素均为合数的区间称为3合数区间,计算该数组中3合数区间的个数。
输入说明:第一行,数组中元素个数N,第二行,N个正整数,用空格隔开。
输出说明:3合数区间的个数
输入样例:7 6 8 4 9 7 5 8输出样例:2
package solution;
import java.util.Scanner;
public class Main2 {
public static void main(String[] args) {
Scanner input = new Scanner(System.in);
int m,res=0;
m = input.nextInt();
int [] arr=new int[m];
for (int i = 0; i < m; i++) {
arr[i]=input.nextInt();
}
for (int i = 0; i < arr.length-2; i++) {
boolean flag=false;
for (int j = i; j < 3+i; j++) {
if(isPrime(arr[j])) {
flag=true;
}
}
if(!flag) {
res++;
}
}
System.out.println(res);
}
private static boolean isPrime(int n) {
boolean flag = true;
for (int i = 2; i < n; i++) {
if (n % i == 0) {
flag = false;
}
}
return flag;
}
}
3:题目3
18.给定两个字符串,均只包含英文字母,需区分大小写,一个是源字符串SS(长度<1000),另一个是目标字符串TS(长度<1000),请问能否通过删除SS中的字符(不改变顺序)将它变换成TS,如果可以输出“YES",不可以则输出“NO"。
输入说明:第一行为源字符串SS,第二行为目标字符串TS。
输出说明:可以输出“YES",不可以输出“NO"。
输入样例1:Thereisacomputer Treat输出样例1:YES输入样例2:Thereisacomputer Trait输出样例2:NO
package solution; import java.util.ArrayList;
import java.util.Scanner; public class Main3 { public static void main(String[] args) {
Scanner input = new Scanner(System.in); ArrayList<Character> slist=new ArrayList<>(); String strs = input.nextLine();
String dtrs = input.nextLine(); char[] scharArray = strs.toCharArray();
char[] dcharArray = dtrs.toCharArray(); for (int i = 0; i < scharArray.length; i++) {
slist.add(scharArray[i]);
}
int index=0;
for (int i = 0; i < slist.size(); i++) {
if(index>=dcharArray.length) {
break;
}
if(slist.get(i)!=dcharArray[index]) {
slist.remove(i--);
}else {
index++;
}
}
if(slist.size()>dcharArray.length) {
System.out.println("YES");
}else {
System.out.println("NO");
}
}
}
4:题目4
19.数字连连看,给出一个整数数组和一个目标值,请在数组中找到三个元素,它们的和为该目标值。
输入说明:第一行是整数N和T,N(N<10000)表示整数数组中元素个数,T是目标值。
第二行是N个整数,表示数组中的元素,且每个数的绝对值小于等于100000。
输出说明:找到的这三个匹配元素所在位置(数组元素起始位置为1),中间用一个空格隔开,若存在多个,请输出位置最小的一个(例如:数组为85453,目标值为16,位置125和145均满足条件,输出125);不满足输出-1。
输入样例:7 12
2 8 7 6 3 4 3
输出样例:135
package solution;
import java.util.Scanner;
public class Main4 {
public static void main(String[] args) {
Scanner input = new Scanner(System.in);
int m,n;
m=input.nextInt();
n=input.nextInt();
int [] arr=new int[m];
for (int i = 0; i < arr.length; i++) {
arr[i]=input.nextInt();
}
for (int i = 0; i < arr.length; i++) {
for (int j = 0; j < arr.length; j++) {
for (int k = 0; k < arr.length; k++) {
if(i==j||i==k||j==k)continue;
if(arr[i]+arr[j]+arr[k]==n) {
System.out.println((i+1)+" "+(j+1)+" "+(k+1));
return ;
}
}
}
}
}
}
5:题目5
20.给定一个只包含0-9、+'、’*的合法数学表达式(长度<1000),规定加号‘+”的优先级高于乘号*”,请输出计算结果。输入说明:合法的数学表达式
输出说明:输出表达式的计算结果
输入样例:12*3+12*2输出样例:360
正确代码:
package app; import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.ArrayList;
import java.util.Stack; public class Main{ public static void main(final String[] args) throws IOException {
final BufferedReader input = new BufferedReader(new InputStreamReader(System.in));
final String formula = input.readLine();
final String[] digitalstrs = formula.split("[+|*]");
char [] formularr=formula.toCharArray();
// 数字串
final int [] arr=new int[digitalstrs.length];
for (int i = 0; i < digitalstrs.length; i++) {
arr[i]=Integer.parseInt(digitalstrs[i]);
}
// 符号串
final char [] srcop=new char[500];
int index=0;
for (int i = 0; i < formularr.length; i++) {
if(formularr[i]=='+'||formularr[i]=='*'){
srcop[index++]=formularr[i];
}
}
// 合并串
ArrayList<String> finals=new ArrayList<>();
int tindex1=0;// 零时指针
int tindex2=0;
for (int i = 0; i < arr.length+index; i++) {
if(i%2==0){
finals.add(arr[tindex1++]+"");
}else{
finals.add(srcop[tindex2++]+"");
}
}
System.out.println(finals);
System.out.println(formularr);
// 结果缓存
Stack<Integer> calcnums = new Stack<>();
// 操作符号
Stack<Character> opr = new Stack<>();
for (int i = 0; i < finals.size(); i++) {
if(finals.get(i).equals("+")){
int x=calcnums.pop();
int res=x+Integer.parseInt(finals.get(i+1));
calcnums.push(res);
i++;
}else if(finals.get(i).equals("*")){
opr.push( finals.get(i).toCharArray()[0]);
}else{
calcnums.push(Integer.parseInt(finals.get(i)));
}
}
System.out.println(opr);
System.out.println(calcnums);
int res=1;
//处理模式
while(!opr.empty()){
opr.pop();
res=calcnums.pop()*calcnums.pop();
calcnums.push(res);
}
// 特判断 只有+的情况
if(calcnums.size()==1){
System.out.println(calcnums.pop());
}else{
System.out.println(res);
}
//System.out.println(Arrays.toString(op));
}
}
代码有问题: 能过部分, 应该用stack来处理
package solution; import java.util.ArrayList;
import java.util.Arrays;
import java.util.Scanner; public class Main5 { public static void main(String[] args) {
Scanner input = new Scanner(System.in);
String regex=input.nextLine(); String[] charArray = regex.split("[*|+]");
int [] arrx=new int[charArray.length];// 数字串
for (int i = 0; i < charArray.length; i++) {
arrx[i]=Integer.parseInt(charArray[i]);
}
char[] scharArr = regex.toCharArray();
char[] op=new char[1000]; // 操作符号
int index=0;
for (int i = 0; i < scharArr.length; i++) {
if(scharArr[i]=='+'||scharArr[i]=='*') {
op[index++]=scharArr[i];
}
}
ArrayList<Integer> list = new ArrayList<>();
int sum=0;
boolean flag=true;
if(index%2==0)flag=false;
for (int i = 0; i < op.length; i++) {
if(op[i]=='+') {
op[i]='\0';
sum+=arrx[i]+arrx[i+1];
if(!flag&&op[i+1]!='+')list.add(arrx[i]+arrx[i+1]);
arrx[i]=0;
arrx[i+1]=0;
//i++;
}
}
System.out.println(sum);
if(op[4]=='+'&&flag) {
sum+=arrx[arrx.length-1];
System.out.println("sss");
}
int mulsum=1;
for (int i = 0; i < arrx.length; i++) {
if(arrx[i]!=0) {
mulsum*=arrx[i];
}
}
for (int i = 0; i < list.size(); i++) {
mulsum*=list.get(i);
}
System.out.println(op);
System.out.println(list);
System.out.println(Arrays.toString(arrx));
System.out.println(sum);
System.out.println(mulsum);
if(flag)System.out.println(mulsum*sum);
}
}
2019年全国高校计算机能力挑战赛初赛java语言解答的更多相关文章
- 2019年全国高校计算机能力挑战赛初赛C语言解答
http://www.ncccu.org.cn 2019年全国高校计算机能力挑战赛分设大数据算法赛,人工智能算法赛,Office高级应用赛,程序设计赛4大赛项 C语言初赛解答 1:编程1 16.现有一 ...
- 2019年全国高校计算机能力挑战赛初赛C++语言解答
1; 题目一 16.电商促销某种商品时,希望通过打折鼓励消费者组团消费.已知,团队消费金额=该团的人数和*商品单价.打折规则如下:当组团消费者数量不满50人时,商品消费金额没有折扣:消费者数量大于等于 ...
- 2019年全国高校计算机能力挑战赛 C语言程序设计决赛
2019年全国高校计算机能力挑战赛 C语言程序设计决赛 毕竟这个比赛是第一次举办,能理解.. 希望未来再举办时,能够再完善一下题面表述.数据范围. 话说区域赛获奖名额有点少吧.舍友花60块想混个创新创 ...
- 2019年全国高校sql数据库
2019年全国高校名单sql数据库信息: 根据教育部发布的文件整理形成可用.sql文件,导入数据库即可使用. 包括全国高等学校共计2956所,其中:普通高等学校2688所(含独立学院257所),成人高 ...
- 银联高校极客挑战赛 初赛 第一场 B
自学图论的码队弟弟 试图写非递归求解,然后TLE了一下午==,全程找不到bug,换成递归,一发AC 判断环写得很丑== #include<bits/stdc++.h> using name ...
- 全国计算机等级考试二级Python语言程序设计考试大纲
全国计算机等级考试二级Python语言程序设计考试大纲(2018年版) 基本要求 掌握Python语言的基本语法规则. 掌握不少于2个基本的Python标准库. 掌握不少于2个Python第三方库,掌 ...
- <路径算法>哈密顿路径变种问题(2016华为软件精英挑战赛初赛)
原创博客,转载请联系博主! 前言:几天前华为的这个软件精英(算法外包)挑战赛初赛刚刚落幕,其实这次是我第二次参加,只不过去年只入围到了64强(32强是复赛线),最后搞到了一个华为的一顶帽子(感谢交大l ...
- 2019年湖南省大学生计算机程序设计竞赛 (HNCPC2019) 简要题解
2019年湖南省大学生计算机程序设计竞赛 (HNCPC2019) 简要题解 update10.01 突然发现叉姐把这场的题传到牛客上了,现在大家可以有地方提交了呢. 不知道该干什么所以就来水一篇题解 ...
- 2019 年百度之星·程序设计大赛 - 初赛一 C. HDU 6670 Mindis 离散化+dijkstra
题目链接 :http://acm.hdu.edu.cn/showproblem.php?pid=6670 Mindis Time Limit: 4000/2000 MS (Java/Others) M ...
随机推荐
- day 22 面向对象的基础
面向对象: 1.简述编写和执行类中的方法的流程 class Foo: #类的编写 def func(): print("我爱你") obj = Foo() #类的调用和执行 obj ...
- JVM(2)--深入理解java对象创建始终
java对象探秘 java是一门面向对象的语言,我们无时无刻不在创建对象和使用对象,那么java虚拟机是如何创建对象的?又是如何访问对象的?java对象中究竟存储了什么运行时所必需的数据?在学习了ja ...
- centOS系统安装-RabbitMq
前言 消息通知机制是我们在日常业务开发总常常都会遇到:在微服务架构里,消息也是必不可少的,我们可以借助它异步实现很多业务,就拿我们日常的购物需求来说,在我们下单支付之后,我们就可以通过消息机制来异步处 ...
- jsp html 实现隐藏输入框,点击可以取消隐藏&&弹出输入框
jsp代码: <script language="javascript" type="text/javascript"> function chg ...
- Vsftp与PAM虚拟用户
使用yum 安装vsftp yum install vsftpd pam pam-* db4 db4-* 创建一个保存用户及密码的文件 cd /etc/vsftpd/ touch virtual_lo ...
- PHP安全之道3:常见漏洞和攻防
第一篇 SQL注入 安全配置和编程安全并不是万全之法,攻击者往往可以通过对漏洞的试探找到新的突破口,甚至0days. 下面总结以下常见漏洞,在日常开发维护工作中可以留意. *聊聊老朋友:SQL注入漏洞 ...
- 快速搭建 Serverless 在线图片处理应用
作者:倚贤 首先介绍下在本文出现的几个比较重要的概念: 函数计算(Function Compute):函数计算是一个事件驱动的服务,通过函数计算,用户无需管理服务器等运行情况,只需编写代码并上传.函数 ...
- POJ1458 Subsquence
A subsequence of a given sequence is the given sequence with some elements (possible none) left out. ...
- unordered_map / HashTable 的负载因子是什么意思
// in C++ 前段时间在看一些关于这个的文章时遇到了一些问题:unordered_map / HashTable 的负载因子是什么意思 经过度娘的搜索,最后得出: 若设 Hash 表的桶数量为 ...
- 分布式监控数据采集系统Ganglia实战
一.什么是Ganglia 对于这个工具,大家可能比较陌生,但是它功能非常强大,如果我们想收集所有服务器.网络设备的数据,那么ganglia绝对是首选,在深入学习之前,还是先从基础概念了解起吧! Gan ...