深度优先

这个家伙好懒,除了文章什么都没留下

0%

【算法】前缀表达式、最小乘积(基本型)、Torry的困惑(基本型)

PPP….s:今天去买体力活了,上午给老妈拼了个鞋架,下午又被拉去干苦力。手现在还痛着,本来不想刷题的,但由于之前说的每天至少一题,所以呢就找几题简单的。唉,真的好简单。然后一下刷了五题,还是把它们贴出来吧。不然缺一天不太好。最后两题还是有点价值的

算法训练 前缀表达式
时间限制:1.0s 内存限制:512.0MB

问题描述
编写一个程序,以字符串方式输入一个前缀表达式,然后计算它的值。输入格式为:“运算符 对象1 对象2”,其中,运算符为“+”(加法)、“-”(减法)、“*”(乘法)或“/”(除法),运算对象为不超过10的整数,它们之间用一个空格隔开。要求:对于加、减、乘、除这四种运算,分别设计相应的函数来实现。
输入格式:输入只有一行,即一个前缀表达式字符串。
输出格式:输出相应的计算结果(如果是除法,直接采用c语言的“/”运算符,结果为整数)。
输入输出样例
样例输入

  • 5 2
    样例输出
    7

代码:

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
-25 6

这个题有技巧,如果利用穷举,全排列,然后在一个个求,就真的上了日本鬼子的当了。两个数组中最大的乘以最小的就是最下乘积了。主要是自己忘了全排列,哈哈哈

代码:

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的值。
样例输入

1
1 

样例输出

1
2

这个题是再常见不过的质因数题了,求质因数有技巧的,测10010010也可以。代码:

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;
}
}
}
}
}