PPP….s:今天去买体力活了,上午给老妈拼了个鞋架,下午又被拉去干苦力。手现在还痛着,本来不想刷题的,但由于之前说的每天至少一题,所以呢就找几题简单的。唉,真的好简单。然后一下刷了五题,还是把它们贴出来吧。不然缺一天不太好。最后两题还是有点价值的
算法训练 前缀表达式 时间限制:1.0s 内存限制:512.0MB
问题描述 编写一个程序,以字符串方式输入一个前缀表达式,然后计算它的值。输入格式为:“运算符 对象1 对象2”,其中,运算符为“+”(加法)、“-”(减法)、“*”(乘法)或“/”(除法),运算对象为不超过10的整数,它们之间用一个空格隔开。要求:对于加、减、乘、除这四种运算,分别设计相应的函数来实现。 输入格式:输入只有一行,即一个前缀表达式字符串。 输出格式:输出相应的计算结果(如果是除法,直接采用c语言的“/”运算符,结果为整数)。 输入输出样例 样例输入
代码:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 import java.util.Scanner; public class 前缀表达式 { public static void main(String[] args) { Scanner sc=new Scanner(System.in); while(sc.hasNext()){ String shizi=sc.nextLine(); String[] ch=shizi.split(" "); int num1=Integer.parseInt(ch[1]); int num2=Integer.parseInt(ch[2]); if(ch[0].equals("+")){ System.out.println(num1+num2); }else if(ch[0].equals("-")){ System.out.println(num1-num2); }else if(ch[0].equals("*")){ System.out.println(num1*num2); }else if(ch[0].equals("/")){ System.out.println(num1/num2); } } } }
算法训练 动态数组使用 时间限制:1.0s 内存限制:512.0MB
1 从键盘读入n个整数,使用动态数组存储所读入的整数,并计算它们的和与平均值分别输出。要求尽可能使用函数实现程序代码。平均值为小数的只保留其整数部分。
1 2 3 4 5 样例输入: 5 3 4 0 0 2 样例输出: 9 1
1 2 3 4 5 样例输入: 7 3 2 7 5 2 9 1 样例输出: 29 4
我想问这个动态数组就几毛钱关系的,代码:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 import java.util.Scanner; public class 动态数组使用 { public static void main(String[] args) { Scanner sc=new Scanner(System.in); while(sc.hasNext()){ int n=sc.nextInt(); int sum=0; for (int i = 0; i < n; i++) { sum+=sc.nextInt(); } System.out.println(sum+" "+sum/n); } } }
算法训练 删除数组零元素 时间限制:1.0s 内存限制:512.0MB
1 从键盘读入n个整数放入数组中,编写函数CompactIntegers,删除数组中所有值为0的元素,其后元素向数组首端移动。注意,CompactIntegers函数需要接受数组及其元素个数作为参数,函数返回值应为删除操作执行后数组的新元素个数。输出删除后数组中元素的个数并依次输出数组元素。
1 2 3 4 5 6 样例输入: (输入格式说明:5为输入数据的个数,3 4 0 0 2 是以空格隔开的5个整数) 5 3 4 0 0 2 样例输出:(输出格式说明:3为非零数据的个数,3 4 2 是以空格隔开的3个非零整数) 3 3 4 2
1 2 3 4 5 6 样例输入: 7 0 0 7 0 0 9 0 样例输出: 2 7 9
1 2 3 4 5 样例输入: 3 0 0 0 样例输出: 0
自己写的还是蛮好的,代码:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 import java.util.Scanner; public class 删除数组零元素 { public static void main(String[] args) { Scanner sc=new Scanner(System.in); while(sc.hasNext()){ int n=sc.nextInt(); int[] arr=new int[n]; int count=0; for (int i = 0; i < arr.length; i++) { int x=sc.nextInt(); if(x!=0){ arr[count]=x; count++; } } System.out.println(count); for (int i = 0; i < count; i++) { System.out.print(arr[i]+" "); } } } }
算法训练 最小乘积(基本型) 时间限制:1.0s 内存限制:512.0MB
问题描述 给两组数,各n个。 请调整每组数的排列顺序,使得两组数据相同下标元素对应相乘,然后相加的和最小。要求程序输出这个最小值。 例如两组数分别为:1 3 -5和-2 4 1
那么对应乘积取和的最小值应为: (-5) * 4 + 3 * (-2) + 1 * 1 = -25 输入格式 第一个行一个数T表示数据组数。后面每组数据,先读入一个n,接下来两行每行n个数,每个数的绝对值小于等于1000。 n<=8,T<=1000 输出格式 一个数表示答案。 样例输入
1 2 3 1 3 -5 -2 4 1 5 1 2 3 4 5 1 0 1 0 1
样例输出
这个题有技巧,如果利用穷举,全排列,然后在一个个求,就真的上了日本鬼子的当了。两个数组中最大的乘以最小的就是最下乘积了。主要是自己忘了全排列,哈哈哈
代码:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 import java.util.Scanner; public class 最小乘积基本型 { public static void main(String[] args) { Scanner sc=new Scanner(System.in); while(sc.hasNext()){ int x=sc.nextInt(); int[] result=new int[x]; for (int k = 0; k < result.length; k++) { int n=sc.nextInt(); int[] arr1=new int[n]; int[] arr2=new int[n]; for (int i = 0; i < arr2.length; i++) { arr1[i]=sc.nextInt(); } for (int i = 0; i < arr2.length; i++) { arr2[i]=sc.nextInt(); } for (int i = 0; i < arr2.length; i++) { for (int j = 0; j < arr2.length; j++) { if(arr1[i]<arr1[j]){ int tmep=arr1[i]; arr1[i]=arr1[j]; arr1[j]=tmep; } if(arr2[i]>arr2[j]){ int tmep=arr2[i]; arr2[i]=arr2[j]; arr2[j]=tmep; } } } int sum=0; for (int i = 0; i < arr2.length; i++) { sum+=arr1[i]*arr2[i]; } result[k]=sum; } for (int i = 0; i < result.length; i++) { System.out.println(result[i]); } } } }
算法训练 Torry的困惑(基本型) 时间限制:1.0s 内存限制:512.0MB
问题描述 Torry从小喜爱数学。一天,老师告诉他,像2、3、5、7……这样的数叫做质数。Torry突然想到一个问题,前10、100、1000、10000……个质数的乘积是多少呢?他把这个问题告诉老师。老师愣住了,一时回答不出来。于是Torry求助于会编程的你,请你算出前n个质数的乘积。不过,考虑到你才接触编程不久,Torry只要你算出这个数模上50000的值。 输入格式 仅包含一个正整数n,其中n<=100000。 输出格式 输出一行,即前n个质数的乘积模50000的值。 样例输入
样例输出
这个题是再常见不过的质因数题了,求质因数有技巧的,测100100 10也可以。代码:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 import java.util.Scanner; public class Torry的困惑基本型 { public static void main(String[] args) { Scanner sc=new Scanner(System.in); while(sc.hasNext()){ int n=sc.nextInt(); //long t1=System.currentTimeMillis(); if(n==0) System.out.println(0); if(n==1) System.out.println(2); int count=1; int sum=2; for (int i = 3; ; i+=2) { boolean fa=true; for (int j = 3; j*j <= i; j++) { if(i%j==0){ fa=false; break; } } if(fa){ sum*=i; if(sum>50000) sum%=50000; count++; } if(count==n){ System.out.println(sum); //long t2=System.currentTimeMillis(); //System.out.println(t2-t1);//2794 return; } } } } }