ACM模式之输入输出(Java/Python例题)
https://github.com/QInzhengk/Math-Model-and-Machine-Learning
力扣刷题用的是核心代码模式,而牛客用的是ACM模式;由于ACM竞赛题目的输入数据和输出数据一般有多组(不定),并且格式多种多样,所以,如何处理题目的输入输出是对大家的一项最基本的要求。这也是困扰初学者的一大问题。
一、Java
1. 输入:
1 |
|
读一个整数:int n = sc.nextInt();
读一个字符串:String s = sc.next();(以空格作为分隔符)
读一个浮点数:double t =sc.nextDouble();
读一整行:String s = sc.nextLine();
判断是否有下一个输入可以用sc.hasNext()或sc.hasNextInt()或sc.hasNextDouble()或sc.hasNextLine()
2. 输出
System.out.println();//换行打印,输出之后会自动换行
System.out.print();//不换行打印
System.out.printf();//按格式输出
3. 字符串处理 String
String 类用来存储字符串,可以用charAt方法来取出其中某一字节,计数从0开始:
1 |
|
用substring方法可得到子串,如上例
1 |
|
注意第2个参数位置上的字符不包括进来。这样做使得 s.substring(a, b) 总是有 b-a个字符。
字符串连接可以直接用 + 号,如
1 |
|
如想直接将字符串中的某字节改变,可以使用另外的StringBuffer类。
4. 高精度
BigInteger和BigDecimal可以说是acmer选择java的首要原因。
函数:add, subtract, divide, mod, compareTo等,其中加减乘除模都要求是BigInteger(BigDecimal)和BigInteger(BigDecimal)之间的运算,所以需要把int(double)类型转换为BigInteger(BigDecimal),用函数BigInteger.valueOf().
5. 进制转换
String st = Integer.toString(num, base); // 把num当做10进制的数转成base进制的st(base <= 35).
int num = Integer.parseInt(st, base); // 把st当做base进制,转成10进制的int(parseInt有两个参数,第一个为要转的字符串,第二个为说明是什么进制).
BigInter m = new BigInteger(st, base); // st是字符串,base是st的进制.
6. 数组排序
函数:Arrays.sort();
二、Python
1.输入:
input为字符串,int强制转换成整形;多组例子使用while
1 |
|
2.输出:
print(*objects, sep=’ ‘, end=’\n’, file=sys.stdout)
参数的具体含义如下:
- objects –表示输出的对象。输出多个对象时,需要用 , (逗号)分隔。
- sep – 用来间隔多个对象。
- end –用来设定以什么结尾。默认值是换行符 \n,我们可以换成其他字符。
- file – 要写入的文件对象。
3.sort和sorted
python中列表的内置函数sort()可以对列表中的元素进行排序,而全局性的sorted()函数则对所有可迭代的序列都是适用的;并且sort()函数是内置函数,会改变当前对象,而sorted()函数只会返回一个排序后的当前对象的副本,而不会改变当前对象。
1、内置函数sort(fun,key,reverse=False)
- 参数fun是表明此sort函数是基于何种算法进行排序的,一般默认情况下python中用的是归并排序
- 参数key用来指定一个函数,此函数在每次元素比较时被调用,此函数代表排序的规则,也就是你按照什么规则对你的序列进行排序
- 参数reverse是用来表明是否逆序,默认的False情况下是按照升序的规则进行排序的,当reverse=True时,便会按照降序进行排序
1 |
|
2、全局函数sorted()
sorted(iterable, key=None, reverse=False)
对于sorted()函数中key的重写,和sort()函数中是一样的,所以刚刚对于sort()中讲解的方法,都是适用于sorted()函数。
4.幂运算:
**
5.index
Python index() 方法检测字符串中是否包含子字符串 str ,如果指定 beg(开始) 和 end(结束) 范围,则检查是否包含在指定范围内,该方法与 python find()方法一样,只不过如果str不在 string中会报一个异常。
index()方法语法:
str.index(str, beg=0,end=len(string))
参数:
- str – 指定检索的字符串
- beg – 开始索引,默认为0。
- end – 结束索引,默认为字符串的长度。
返回值:如果包含子字符串返回开始的索引值,否则抛出异常。
6.any
any(iterable):参数iterable – 元组或列表。
返回值:如果都为空、0、false,则返回false,如果不都为空、0、false,则返回true。
7.isdigit()方法
isdigit() 方法检测字符串是否只由数字组成,只对 0 和 正数有效。
8.浮点数输出
1、格式化输出
- %f ——保留小数点后面六位有效数字
- %.3f,保留3位小数位
1 |
|
2、format 格式化函数
格式化字符串函数 str.format(),基本语法是通过 {} 和 : 来代替以前的 % 。format 函数可以接受不限个参数,位置可以不按顺序。
1 |
|
3、内置round(number[, ndigits])
- number - 这是一个数字表达式。
- ndigits - 表示从小数点到最后四舍五入的位数。默认值为0。
- 该方法返回x的小数点舍入为n位数后的值。
9.set
交集 & : x&y,返回一个新的集合,包括同时在集合 x 和y中的共同元素。
并集 | : x|y,返回一个新的集合,包括集合 x 和
y 中所有元素。差集 - : x-y,返回一个新的集合,包括在集合 x 中但不在集合 y 中的元素。
补集 ^ : x^y,返回一个新的集合,包括集合 x 和 y 的非共同元素。
10.ord()
ord() 函数是 chr() 函数(对于 8 位的 ASCII 字符串)的配对函数,它以一个字符串(Unicode 字符)作为参数,返回对应的 ASCII 数值,或者 Unicode 数值。
三、编程题
1、矩阵元素相乘
A[n,m]是一个n行m列的矩阵,a[i,j]表示A的第i行j列的元素,定义x[i,j]为A的第i行和第j列除了a[i,j]之外所有元素(共n+m-2个)的乘积,即x[i,j]=a[i,1]a[i,2]…a[i,j-1]…*a[i,m]*a[1,j]*a[2,j]…*a[i-1,j]*a[i+1,j]…*a[n,j],现输入非负整形的矩阵A[n,m],求MAX(x[i,j]),即所有的x[i,j]中的最大值。
输入描述:
第一行两个整数n和m。之后n行输入矩阵,均为非负整数。
输出描述:
一行输出答案。
示例1
输入
1 |
|
输出
1 |
|
Java
1 |
|
Python
1 |
|
2、有序数组去重
给定一个字符串,字符串是有序的整数集合,逗号相连,移除相同的数字,使每个数字只出现一次,输出最终的数字个数。
输入描述:
1,2,2
输出描述:
2
示例1
输入
1 |
|
输出
1 |
|
示例2
输入
1 |
|
输出
1 |
|
备注:
有序整数字符串集合请在控制台一行内完成输入,并用英文逗号(,)相隔,如:1,2,2
Java
1 |
|
Python
1 |
|
3、最大子序列和
给一个长度为N的序列a1,a2,…,an,求最大连续和。也即,寻找1<=i<=j<=N,使得ai+…+aj尽量大。
输入描述:
一行, 整数序列, 逗号分隔
输出描述:
一行, 整数, 表示最大子序列和
示例1
输入
1 |
|
输出
1 |
|
Java
1 |
|
Python
1 |
|
4、回文串
回文串是指字符串无论从左读还是从右读,所读的顺序是一样的;简而言之,回文串是左右对称的。
现给定一个字符串,求出它的最长回文子串。你可以假定只有一个满足条件的最长回文串。
输入描述:
一行, 字符串
输出描述:
一行, 字符串
示例1
输入
1 |
|
输出
1 |
|
Python
1 |
|
5、变形词
对于两个字符串A和B,如果A和B中出现的字符种类相同且每种字符出现的次数相同,则A和B互为变形词,请设计一个高效算法,检查两给定串是否互为变形词。
给定两个字符串A和B,请返回一个bool值,代表他们是否互为变形词。
输入描述:
1 |
|
输出描述:
bool 值
示例1
输入
1 |
|
输出
1 |
|
Python
1 |
|
6、连续质数表示
一些正数能被表示成一个或者多个连续质数的和。那一个数会有多少种这样的表示方式呢?比如说数字41能有3种表示方式:2+3+5+7+11+13,11+13+17,和41;数字3只有本身这一种表示方式;而20没有这样的表示方式。写一个程序生成给定数字的表示方式数量吧。数字大小范围从2到10,000。
输入描述:
一行,包含一个2到10000的正整数
输出描述:
一行, 非负整数, 给定数字的表示方式数量
示例1
输入
1 |
|
输出
1 |
|
Python
1 |
|
四、Python编程之算法岗笔试题
1、找零钱的所有可能数
对于1-100之间任意钱,换成等值的10元、5元、2元、1元的小钞票,编程输出所有可能的总数
问题分析
对于零钱n,条件x * 1 + y * 2 + z * 5 + m * 10 = n,找出符合条件的(x,y,z,m)的总数。
1 |
|
2、重排序列
给定一个长度为N的序列A1到AN,现在要对序列进行M次操作,每次操作对序列的前若干项进行升序或降序排列,求经过这M次操作后得到的序列。
输入描述
第一行包含两个整数N和M,1≤N,M≤10^5。 第二行包含N个空格隔开的整数A1到AN,1≤Ai≤10^9。
接下来M行,每行包含两个整数t和x,0≤t≤1,1≤x≤N。若t=0,则表示对A1到Ax进行升序排列;若t=1,则表示对A1到Ax进行降序排列。操作执行顺序与输入顺序一致。
输出描述
输出N个空格隔开的整数,即经过M次操作后得到的序列。
1 |
|
参考: