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 ...
随机推荐
- 护网杯一道crypto
import os def xor(a,b): assert len(a)==len(b) c="" for i in range(len(a)): c+=chr(ord(a[i] ...
- 【如何让代码变“高级”(一)】-Spring组合注解提升代码维度
原创不易,点个赞
- java Random类详解
java Random类位于java.util包下,主要用来生成随机数,本文详解介绍了Random类的用法,希望能帮到大家 Random类 (java.util) Random类中实现的随机算法是伪随 ...
- JavaScript-----2初识
1.介绍 JavaScript是一种运行在客户端(自己的电脑上)的脚本语言不是在服务器上 脚本语言:不需要编译,运行过程由JS解释器(js引擎)逐行进行解释并执行 JavaScript不仅可以做前端编 ...
- 使用HttpReports快速搭建API分析平台
HttpReports 简单介绍 HttpReports 是 .Net Core下的一个Web组件,适用于 WebAPI 项目和 API 网关项目,通过中间件的形式集成到您的项目中, 通过HttpRe ...
- 一句话总结flux,以及我们为何需要flux
如果让你用一句话总结一下什么是flux,该怎么说? 官网上有这样的介绍:flux是一种思想,一种框架,是facebook给react... 这样的解释对程序员来说,显得过于抽象又不具体了. 阮老师的文 ...
- LVS+Keepalived-DR模式(Apache)
Environment:4台CentOS机器 两台LVS 两台web服务器 LVS主备的操作,都需要安装ipvsadm和keepalived LVS主机操作 : 1.更改Keepalived的配置文件 ...
- Magicodes.Sms短信库的封装和集成
简介 Magicodes.Sms是心莱团队封装的短信服务库,已提供Abp模块的封装. Nuget 新的包 名称 说明 Nuget Magicodes.Sms.Aliyun 阿里云短信库 Magicod ...
- DOM中的获得元素的方式
获取元素的方式:分为俩种: 1.直接获取:直接获取分为三种: a,获取单个元素: function demo1(){ var uid=document.getElementById("use ...
- [TimLinux] JavaScript AJAX如何重定向页面
1. AJAX 异步JavaScript + XML,用于不通过页面from表单,来发送数据到后端服务器中 2. 如何重定向 服务器后端无法直接将页面重定向,因为服务器后端传回的任何数据,都将被XML ...