[JAVA] ACM模式下输入输出

这篇具有很好参考价值的文章主要介绍了[JAVA] ACM模式下输入输出。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

ACM模式下输入输出

经典十一道题

题一 多行数据,有行数限制,每行有个数限制

输入描述:

输入的第一行包括一个正整数t(1 <= t <= 100), 表示数据组数。
接下来 t 行, 每行一组数据。
每行的第一个整数为整数的个数n(1 <= n <= 100)。
接下来n个正整数, 即需要求和的每个正整数。

输出描述:

每组数据输出求和的结果

import java.util.*;
public class Main {
    public static void main(String[] args){
        Scanner in = new Scanner(System.in);
        //将求和结果先放在数组中
        List<Integer> list = new ArrayList<Integer>();
        int t  = in.nextInt();
        for(int i = 0; i < t; i++){
            int n = in.nextInt();
            int[] nums = new int[n];
            int sum = 0;
            for(int j = 0; j < n; j++){
                nums[j] = in.nextInt();
                sum += nums[j];
            }
            list.add(sum);
        }
        //逐项按列输出数组元素
        list.forEach(e->System.out.println(e));
    }
}

输出结果:

java acm模式输入输出,Leetcode 刷题笔记,java,算法

题二 多行数据,每行数据个数限制

输入描述:

输入数据有多组, 每行表示一组输入数据。
每行的第一个整数为整数的个数n(1 <= n <= 100)。
接下来n个正整数, 即需要求和的每个正整数。

输出描述:

每组数据输出求和的结果

import java.util.*;
public class Main{
    public static void main(String[] args){
        Scanner in = new Scanner(System.in);
        while(in.hasNext()){
            int n = in.nextInt();
            int res  = 0 ;
            while(n > 0){
                res += in.nextInt();
                n--;
            }
            System.out.println(res);
        }
    }
}

输出结果:
java acm模式输入输出,Leetcode 刷题笔记,java,算法

题三 多组两数相加

输入描述:

输入包括两个正整数a,b(1 <= a, b <= 1000),输入数据包括多组。

输出描述:

输出a+b的结果

import java.util.*;
public class Main {
    public static void main(String[] args){
        Scanner in = new Scanner(System.in);
        while(in.hasNext()){
            int a = in.nextInt();
            int b = in.nextInt();
            System.out.println(a+b);
        }
    }
}

输出结果:
java acm模式输入输出,Leetcode 刷题笔记,java,算法

题四 多组数据,有个数限制 每行仅两个正整数

输入描述:

输入第一行包括一个数据组数 t (1 <= t <= 100)
接下来每行包括两个正整数a,b(1 <= a, b <= 1000)

输出描述:

输出a+b的结果

import java.util.*;
public class Main {
    public static void main(String[] args){
        Scanner in = new Scanner(System.in);
        int t = in.nextInt();
        while(t-- > 0){
            int a = in.nextInt();
            int b = in.nextInt();
            System.out.println(a+b);
        }
    }
}

输出结果:
java acm模式输入输出,Leetcode 刷题笔记,java,算法

题五 多组两位正整数相加,有结束条件

输入描述:

输入包括两个正整数a,b(1 <= a, b <= 10^9),输入数据有多组, 如果输入为0 0则结束输入

输出描述:

输出a+b的结果

import java.util.*;
public class Main {
    public static void main(String[] args) {
        Scanner in = new Scanner(System.in);
        List<Integer> list = new ArrayList<Integer>();
        // 注意 hasNextInt 和 hasNextLine 的区别
        while (in.hasNext()) { 
            int a = in.nextInt();
            int b = in.nextInt();
            if (a == 0 && b == 0) break;
            list.add(a + b);
        }
        list.forEach(e->System.out.println(e));
    }
}
//1、hasNextInt()方法会判断接下来是否有非空字符.如果有,则返回true,否则返回false
//2、hasNextLine() 方法会根据行匹配模式去判断接下来是否有一行(包括空行),如果有,则返回true,否则返回false
// hasNextInt() ---匹配使用--- nextInt()
//hasNextLine() ---匹配使用--- nextLine()

输出结果:
java acm模式输入输出,Leetcode 刷题笔记,java,算法

题六 多组行数据,每行数据个数有限制

输入描述:

输入数据有多组, 每行表示一组输入数据。
每行的第一个整数为整数的个数n(1 <= n <= 100)。
接下来n个正整数, 即需要求和的每个正整数。

输出描述:

每组数据输出求和的结果

import java.util.*;
public class Main {
    public static void main(String[] args) {
        Scanner in = new Scanner(System.in);
        while(in.hasNextInt()){
            int n = in.nextInt();
            int res = 0;
            while(n-- > 0){
                res += in.nextInt();
            }
            System.out.println(res);
        }
    }
}

输出结果:
java acm模式输入输出,Leetcode 刷题笔记,java,算法

题七 多组行数据,以零为结束条件,结果存在数组中输出

输入描述:

输入数据包括多组。
每组数据一行,每行的第一个整数为整数的个数n(1 <= n <= 100), n为0的时候结束输入。
接下来n个正整数,即需要求和的每个正整数。

输出描述:

每组数据输出求和的结果

import java.util.*;
public class Main {
    public static void main(String[] args) {
        Scanner in = new Scanner(System.in);
        List<Integer> list = new ArrayList<Integer>();
        while(in.hasNext()) {
            int n = in.nextInt();
            if (n == 0) break;
            int sum = 0;
            while(n-- > 0){
                sum += in.nextInt();
            }
            list.add(sum);
        }
        list.forEach(e->System.out.println(e));
    }
}

输出结果:
java acm模式输入输出,Leetcode 刷题笔记,java,算法

题八 多组行数据,无个数限制

输入描述:

输入数据有多组, 每行表示一组输入数据。
每行不定有n个整数,空格隔开。(1 <= n <= 100)。

输出描述:

每组数据输出求和的结果

import java.util.*;
public class Main{
    public static void main(String[] args){
        Scanner in = new Scanner(System.in);
        while(in.hasNext()){
            String[] str = in.nextLine().split(" ");
            int res =  0;
            for(int i=0; i<str.length; i++){
                res += Integer.parseInt(str[i]);
            }
            System.out.println(res);
        }
    }
}

输出结果:
java acm模式输入输出,Leetcode 刷题笔记,java,算法

题九 字符串排序,字符串之间用空格隔开

输入描述:

输入有两行,第一行n
第二行是n个字符串,字符串之间用空格隔开

输出描述:

输出一行排序后的字符串,空格隔开,无结尾空格
import java.util.*;
public class Main {
    public static void main(String[] args){
        Scanner in = new Scanner(System.in);
        while(in.hasNext()){
            int n = in.nextInt();
            String[] str = new String[n];
            for (int i = 0; i < n; i++) {
                str[i] = in.next();
            }
            Arrays.sort(str);
            for (String s:str) {
                System.out.print(s + " ");
            }
        }
    }
}

输出结果:
java acm模式输入输出,Leetcode 刷题笔记,java,算法

题十 多个字符串测试用例,每行以空格隔开

输入描述:

多个测试用例,每个测试用例一行。
每行通过空格隔开,有n个字符,n<100

输出描述:

对于每组测试用例,输出一行排序过的字符串,每个字符串通过空格隔开
import java.util.*;
public class Main{
    public static void main(String[] args){
        Scanner in = new Scanner(System.in);
        while(in.hasNext()){
            String[] str = in.nextLine().split(" ");
            Arrays.sort(str);
            for (String s:str) {
                System.out.print(s + " ");
            }
            System.out.println();
     }
   }
}

输出结果:
java acm模式输入输出,Leetcode 刷题笔记,java,算法

题十一 多个字符串测试用例,每行以逗号隔开

输入描述:

多个测试用例,每个测试用例一行。
每行通过,隔开,有n个字符,n<100

输出描述:

对于每组用例输出一行排序后的字符串,用','隔开,无结尾空格
import java.util.*;
public class Main{
    public static void main(String[] args){
        Scanner in = new Scanner(System.in);
        while(in.hasNext()){
            String[] str = in.nextLine().split(",");
            Arrays.sort(str);
            int len = str.length;
            for (int i = 0; i<len-1; i++) {
                System.out.print(str[i]+ "," );
            }
            System.out.println(str[len-1]);
        }
    }
}

输出结果:
java acm模式输入输出,Leetcode 刷题笔记,java,算法文章来源地址https://www.toymoban.com/news/detail-650033.html

到了这里,关于[JAVA] ACM模式下输入输出的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • ACM模式输入输出攻略 | C++篇

    大家好,这里是小黛~ 三月开始,就会陆续开启各大公司暑期实习的笔试和面试,而笔试中,ACM模式是必须要去 熟练掌握 的,今天就来针对ACM模式进行详细介绍。 这个系列首先以C++为例,进行ACM模式的讲解,后续会补齐JAVA、GO、JS等常用语言的输入输出案例。 本文主要介绍

    2024年02月02日
    浏览(31)
  • ACM模式输入输出练习(JS V8模式 + JS node模式)

    目录 JavaScript V8模式 JavaScript node模式 题目类型一:A+B 第一题:输入包括两个正整数a,b(1 = a, b = 1000),输入数据包括多组。 第二题:输入第一行包括一个数据组数t(1 = t = 100),接下来每行包括两个正整数a,b(1 = a, b = 1000) 第三题:输入包括两个正整数a,b(1 = a, b = 10^9),输入数据有多

    2024年02月11日
    浏览(27)
  • 【ACM竞赛入门】001.一文读懂常见的ACM题型输入输出格式

    本文通过各种类型的A+B题目来帮助大家快速了解ACM题目中常见的输入输出格式,帮助大家快速上手 时间限制: 1s 内存限制: 64MB 题目描述 Your task is to Calculate a + b. Too easy?! Of course! I specially designed the problem for acm beginners. You must have found that some problems have the same titles with this one,

    2024年02月07日
    浏览(29)
  • 华为OD机试ACM输入输出

    华为OD机考是基于牛客平台进行的,且必须采用ACM模式 ACM模式: 机试系统调用你的代码时,传入的都是字符串, 题目的输入描述 会说明字符串的组成规则,你需要根据这些规则从输入字符串中解析出需要的数据。 当算法程序计算出结果后,也不能直接返回给机试系统,因为

    2024年02月06日
    浏览(48)
  • 华为OD机试(2022&2023)ACM输入输出

    华为OD机考是基于牛客平台进行的,且必须采用ACM模式 ACM模式: 机试系统调用你的代码时,传入的都是字符串, 题目的输入描述 会说明字符串的组成规则,你需要根据这些规则从输入字符串中解析出需要的数据。 当算法程序计算出结果后,也不能直接返回给机试系统,因为

    2023年04月27日
    浏览(36)
  • ACM模式各种输入整理(C++)

    本文整理ACM模式的各种输入形式。 2.1.1 在终端的一行中输入 固定数目 的整型数字,并存到数组中,中间以 空格 分隔 示例: 3 1 2 3 方法1 方法2  方法3  正确性测试: 2.1.2 在终端的一行中输入 非固定数目 的整型数字,并存到数组中,中间以 空格(或者其他单字符,./) 分隔

    2024年02月02日
    浏览(22)
  • python_ACM模式《剑指offer刷题》链表1

    询问面试官是否可以改变链表结构 1. 翻转链表,再遍历链表打印。 2. 想要实现先遍历后输出,即先进后出,因此可借助栈结构。 3. 可用隐式的栈结构,递归来实现。 1. 2. 3. 采用递归的思想 注意是递归到最后一个元素才开始打印 即要先写递归 后写打印代码

    2024年01月23日
    浏览(38)
  • LeetCode ACM模式——二叉树篇(一)

    刷题顺序及思路来源于代码随想录,网站地址:https://programmercarl.com  目录 定义二叉树 创建二叉树 利用前序遍历创建二叉树 利用数组创建二叉树 打印二叉树 144. 二叉树的前序遍历 递归遍历 迭代遍历(利用栈) 145. 二叉树的后序遍历 ​编辑递归遍历 迭代遍历(利用栈)

    2024年02月12日
    浏览(26)
  • ACM模式,Python

    当有多组数据输入时,用以下结构: while True:这是一个循环结构,意味着条件始终为真,循环会一直执行下去。 try:这是一个异常处理结构,用于包含可能会产生异常的代码块。 except:这是一个异常捕获结构,当 try 块中发生异常时,会将异常捕获并执行 except 块中的代码

    2024年02月09日
    浏览(23)
  • 算法题的ACM模式与核心代码模式

    身为一名程序员,刷题网站系统我们应该再熟悉不过了,除了针对竞赛的 OJ 系统,比如:POJ;还有很多专为求职提供的刷题 OJ 系统,比如:leetcode、牛客网 等。 这两类 OJ 在刷题模式上有些区别,一般竞赛的 OJ 系统是针对 ACM 模式的,而求职的 OJ 系统是针对核心算法模式的

    2024年02月14日
    浏览(35)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包