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 ...
随机推荐
- leetcode105 从前序与中序遍历序列构造二叉树
如何遍历一棵树 有两种通用的遍历树的策略: 宽度优先搜索(BFS) 我们按照高度顺序一层一层的访问整棵树,高层次的节点将会比低层次的节点先被访问到. 深度优先搜索(DFS) 在这个策略中,我们采用深度 ...
- day03_正则表达式
1.数据分类 数据的分类 定义:数据以行为单位,每一个数据表示一个实体的信息.每一行数据的属性都是一样的. 常见的结构化数据为关系型数据库存储数据. 半结构化数据 定义:结构化数据的另一种 ...
- 折腾笔记-计蒜客T1158-和为给定数AC记
欢迎查看原题 1.简单题目叙述 蒜头君给出若干个整数,询问其中是否有一对数的和等于给定的数. 输入格式 共三行: 第一行是整数 ),表示有 n 个整数. 第二行是 n 个整数.整数的范围是在 0 到 ...
- Dubbo实现登陆
一.目录展示 二.dubbo_logins_service 2.1 实体类和service层 2.2 logins实体类 package com.login.entity; import java.i ...
- .NET进阶篇06-async异步、thread多线程4
知识需要不断积累.总结和沉淀,思考和写作是成长的催化剂 梯子 一.锁1.lock2.Interlocked3.Monitor4.SpinLock5.Mutex6.Semaphore7.Events1. ...
- WPF最简单的分页控件
背景:最近在写项目的时候需要写一个简单的分页功能,因项目需要,没有改为MVVM模式,只需要在后台实现 1.呈现效果如下: 接下来就来上代码,看看怎么实现的 1.界面代码 <StackPanel ...
- 走近深度学习,认识MoXing:初识华为云ModelArts的王牌利器 — MoXing
[摘要] 本文为MoXing系列文章第一篇,主要介绍什么是MoXing,MoXing API的优势以及MoXing程序的基本结构. MoXing的概念 MoXing是华为云深度学习服务提供的网络模型开 ...
- 一条数据的HBase之旅,简明HBase入门教程1:开篇
[摘要] 这是HBase入门系列的第1篇文章,主要介绍HBase当前的项目活跃度以及搜索引擎热度信息,以及一些概况信息,内容基于HBase 2.0 beta2版本.本系列文章既适用于HBase新手,也 ...
- v-bind和v-model的本质区别和作用域
每篇一句 一场寂寞凭谁诉.算前言,总轻负. Vue视图数据展示方式和彼此的区别: {{插值表达式}} {{}}插值表达式里面 只能写表达式,不能写语句 文本输出,不会解析标签 不能作用在标签的属性上, ...
- luogu P2135 方块消除 |dp
题目描述 Jimmy最近迷上了一款叫做方块消除的游戏.游戏规则如下:n个带颜色方格排成一列,相同颜色的方块连成一个区域(如果两个相邻方块颜色相同,则这两个方块属于同一区域).为简化题目,将连起来的同一 ...