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. Android的系统框架

    Android的系统架构采用了分层架构的思想,如图1所示.从上层到底层共包括四层,分别是应用程序程序层.应用框架层.系统库和Android运行时和Linux内核.  图1:Android系统架构图 每 ...

  2. Linux -- 进程间通信几种方式的总结

    管道 优点 管道文件不占磁盘空间,打开管道时在内存中分配空间: 管道读端会在读取完管道内数据后自动进入阻塞,直到写端再次写入数据: 缺点 管道是半双工的,数据只能从一个方向上流动: 管道大小 PIPE ...

  3. vscode启动黑屏

    今天打开vscode的时候突然就黑屏了,一脸懵 于是上网找了一下,根据这位博主的解决办法: https://blog.csdn.net/insgo/article/details/102975986 ...

  4. 灵魂拷问:为什么 Java 字符串是不可变的?

    在逛 programcreek 的时候,发现了一些精妙绝伦的主题.比如说:为什么 Java 字符串是不可变的?像这类灵魂拷问的主题,非常值得深思. 对于绝大多数的初级程序员来说,往往停留在" ...

  5. rep()函数简介

    rep()函数:重复 rep(x,...) rep.int(x,times) rep_len(x,length.out) ·x:一个向量(vector),一个因子(factor),一个POSIXct或 ...

  6. desc和show

    desc只能查看表结构 查看zx1表结构 desc zx1; mysql> desc zx1 -> ; +---------+---------+------+-----+-------- ...

  7. SpringBoot和SpringCloud的版本对应关系

    1.详细的SpringBoot和SpringCloud对应的关系: Spring官方对应关系 2.springCloud与各组件的版本对应关系 官方文档

  8. Spring Boot中使用Jpa的findOne方法不能传入id

    最近通过慕课网学习spring boot,视频中通过jpa的findOne方法以id为参数查询出对应的信息, 而当我自己做测试的时候却发现我的findOne方法的参数没有Integer类型的id,而是 ...

  9. 深入浅出-iOS程序性能优化

    iOS应用是非常注重用户体验的,不光是要求界面设计合理美观,也要求各种UI的反应灵敏,我相信大家对那种一拖就卡卡卡的 TableView 应用没什么好印象.还记得12306么,那个速度,相信大家都受不 ...

  10. MQTT版本升级过程及源码解析

    MQTT版本升级过程及源码解析 首先说一下为什么要写这篇文章呢,在我发现网上对MQTT的文章介绍实在太少了,可能也是使用这个的频率比较低吧!还有对问题的定位以及解决的方式和办法也太少了,所以特意写这篇 ...