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语言解答的更多相关文章

  1. 2019年全国高校计算机能力挑战赛初赛C语言解答

    http://www.ncccu.org.cn 2019年全国高校计算机能力挑战赛分设大数据算法赛,人工智能算法赛,Office高级应用赛,程序设计赛4大赛项 C语言初赛解答 1:编程1 16.现有一 ...

  2. 2019年全国高校计算机能力挑战赛初赛C++语言解答

    1; 题目一 16.电商促销某种商品时,希望通过打折鼓励消费者组团消费.已知,团队消费金额=该团的人数和*商品单价.打折规则如下:当组团消费者数量不满50人时,商品消费金额没有折扣:消费者数量大于等于 ...

  3. 2019年全国高校计算机能力挑战赛 C语言程序设计决赛

    2019年全国高校计算机能力挑战赛 C语言程序设计决赛 毕竟这个比赛是第一次举办,能理解.. 希望未来再举办时,能够再完善一下题面表述.数据范围. 话说区域赛获奖名额有点少吧.舍友花60块想混个创新创 ...

  4. 2019年全国高校sql数据库

    2019年全国高校名单sql数据库信息: 根据教育部发布的文件整理形成可用.sql文件,导入数据库即可使用. 包括全国高等学校共计2956所,其中:普通高等学校2688所(含独立学院257所),成人高 ...

  5. 银联高校极客挑战赛 初赛 第一场 B

    自学图论的码队弟弟 试图写非递归求解,然后TLE了一下午==,全程找不到bug,换成递归,一发AC 判断环写得很丑== #include<bits/stdc++.h> using name ...

  6. 全国计算机等级考试二级Python语言程序设计考试大纲

    全国计算机等级考试二级Python语言程序设计考试大纲(2018年版) 基本要求 掌握Python语言的基本语法规则. 掌握不少于2个基本的Python标准库. 掌握不少于2个Python第三方库,掌 ...

  7. <路径算法>哈密顿路径变种问题(2016华为软件精英挑战赛初赛)

    原创博客,转载请联系博主! 前言:几天前华为的这个软件精英(算法外包)挑战赛初赛刚刚落幕,其实这次是我第二次参加,只不过去年只入围到了64强(32强是复赛线),最后搞到了一个华为的一顶帽子(感谢交大l ...

  8. 2019年湖南省大学生计算机程序设计竞赛 (HNCPC2019) 简要题解

    2019年湖南省大学生计算机程序设计竞赛 (HNCPC2019) 简要题解 update10.01 突然发现叉姐把这场的题传到牛客上了,现在大家可以有地方提交了呢. 不知道该干什么所以就来水一篇题解 ...

  9. 2019 年百度之星·程序设计大赛 - 初赛一 C. HDU 6670 Mindis 离散化+dijkstra

    题目链接 :http://acm.hdu.edu.cn/showproblem.php?pid=6670 Mindis Time Limit: 4000/2000 MS (Java/Others) M ...

随机推荐

  1. 用.net core mvc 开发一个虽小但五脏俱全的网站

    .net core mvc 发布有很长时间了,但是一直没有用过,最近突然想开发一个导航网站,于是就抽时间开发了一个专门为开发者使用的导航站点,想看的话请移步我的上一篇博客https://www.cnb ...

  2. python爬取中国知网部分论文信息

    爬取指定主题的论文,并以相关度排序. #!/usr/bin/python3 # -*- coding: utf-8 -*- import requests import linecache impor ...

  3. docker实例之mysql的使用

    docker实例之mysql的使用 常用步骤 命令 1:搜索镜像 docker search xxx 2:拉取镜像 docker pull xxx:yy 3:查看镜像 docker image ins ...

  4. 【Luogu P2515】软件安装

    Luogu P2515 这道题的题面与P2146有点像.一些不同地方就是P2146是无环的,这题是有环的. 很显然,如果有几个软件的依赖关系形成环,那么这几个软件就可以被看成是一个大软件,其价值和空间 ...

  5. 探究 C# 中的 char 、 string(一)

    目录 探究 C# 中的 char . string(一) 1. System.Char 字符 2. 字符处理 3. 全球化 4. System.String 字符串 4.1 字符串搜索 4.2 字符串 ...

  6. 转载 :c# 获取net framework 版本(Environment 类)

    源链接:http://www.cnblogs.com/tobecrazy/p/3362446.html 根据自己使用情况,添加了部分备注 1.获取当前操作系统版本信息 使用Environment.OS ...

  7. C++桌面计算机

    #include<iostream> #include<string> #include<map> #include<cctype> using nam ...

  8. 【10分钟学Spring】:@Profile、@Conditional实现条件化装配

    根据不同的环境来装配不同的bean 企业级开发中,我们一般有多种环境,比如开发环境.测试环境.UAT环境和生产环境.而系统中有些配置是和环境强相关的,比如数据库相关的配置,与其他外部系统的集成等. 如 ...

  9. 曹工杂谈:Spring boot应用,自己动手用Netty替换底层Tomcat容器

    前言 问:标题说的什么意思? 答:简单说,一个spring boot应用(我这里,版本升到2.1.7.Release了,没什么问题),默认使用了tomcat作为底层容器来接收和处理连接. 我这里,在依 ...

  10. 普通莫队--洛谷P1997 【faebdc的烦恼】

    离散化+莫队 cnt数组表示某个颜色出现的次数 sum数组表示某个数量出现的颜色种类 其它细节问题就按照莫队的模板来的 #include<cstdio> #include<algor ...