笔试题

https://www.tuhd.top/2017/08/02/2017-08-02-%E6%8B%BC%E5%A4%9A%E5%A4%9A%E7%AC%94%E8%AF%95/

模拟乘法, 大数乘法

import java.util.Scanner;
/**
 * Created by thd on 2017/8/1
 */
public class Main2 {
    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        String s1 = sc.next();
        String s2 = sc.next();
        int[] a = new int[s1.length()];
        int[] b = new int[s2.length()];
        int[] c = new int[s1.length() + s2.length()];
        for (int i = 0; i < s1.length(); i++) {
            a[s1.length() - 1- i] = s1.charAt(i) - '0';
        }
        for (int i = 0; i < s2.length(); i++) {
            b[s2.length() - 1 - i] = s2.charAt(i) - '0';
        }
        for (int i = 0; i < s1.length(); i++) {
            for (int j = 0; j < s2.length(); j++) {
                c[i+j]+=a[i]*b[j];
            }
        }
        for (int i = 0; i < c.length - 1; i++) {
            c[i+1]+=c[i]/10;
            c[i]=c[i]%10;
        }
        StringBuffer sb = new StringBuffer();
        boolean flag = true;
        for (int i = c.length - 1; i >= 0; i--) {
            if (c[i] == 0 && flag) {
                continue;
            } else {
                flag = false;
            }
            sb.append(c[i]);
        }
        if (flag) System.out.println(0);
        else
            System.out.println(sb.toString());
    }
}
复制代码

探险

import java.util.*;
/**
 * Created by thd on 2017/8/1
 */
import java.util.*;
 
public class Main {
     
    static class Node{
        int x;
        int y;
        int key;
        int step;
        public Node(int x,int y,int key,int step){
            this.x=x;
            this.y=y;
            this.key=key;
            this.step=step;
        }
    }
    public static void main(String[] args){
        Scanner in=new Scanner(System.in);
        int N=in.nextInt();
        int M=in.nextInt();
        in.nextLine();
        char[][] G=new char[N][M];
        for(int i=0;i<N;i++){
            G[i]=in.nextLine().toCharArray();
        }
        for(int i=0;i<N;i++){
            for(int j=0;j<M;j++){
                if(G[i][j]=='2'){
                    System.out.println(bfs(i,j,N,M,G));
                    return;
                }
            }
        }
    }
    private static int bfs(int si, int sj,int N,int M,char[][] G) {
        Queue<Node> queue=new LinkedList<>();
        int[][][] mp=new int[101][101][1025];
        int[][] next={{-1,0},{0,-1},{1,0},{0,1}};
         
        queue.offer(new Node(si,sj,0,0));
        while(!queue.isEmpty()){
            Node node=queue.poll();
            for(int i=0;i<4;i++){
                int x=node.x+next[i][0];
                int y=node.y+next[i][1];
                int key=node.key;
                if(x<0||x>=N||y<0||y>=M||G[x][y]=='0') continue;
                // 如果走到了出口 直接return 
                else if(G[x][y]=='3') return node.step+1;
                // 如果走到了有钥匙的位置,捡钥匙
                else if(G[x][y]<='z'&&G[x][y]>='a') key=key|(1<<(G[x][y]-'a'));
                // 如果走到了门的位置,判断是否已经有这个门的钥匙,如果没有就没法走
                else if(G[x][y]<='Z'&&G[x][y]>='A'&&(key&(1<<(G[x][y]-'A')))==0) continue;
                // 将走过的位置标记为1
                if(mp[x][y][key]==0){
                    mp[x][y][key]=1;
                    queue.offer(new Node(x,y,key,node.step+1));
                }
                 
            }
        }
        return -1;
    }
     
}
复制代码

分巧克力

public class Main3 {
    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        int n = sc.nextInt();
        int[] h = new int[n];
        for (int i = 0; i < n; i++) {
            h[i] = sc.nextInt();
        }
        int m = sc.nextInt();
        int[] w = new int[m];
        for (int i = 0; i < m; i++) {
            w[i] = sc.nextInt();
        }
        Arrays.sort(h);
        Arrays.sort(w);
        int res = 0;
        int j = 0;
        for (int i = 0; i < h.length; i++) {
            if (w[j++] >= h[i]) {
                res++;
            }
            else
                i--;
            if (j == w.length) break;
        }
        System.out.println(res);
    }
}

复制代码

找数组中3个数字的最大乘积


import java.util.Scanner;
/**
 * Created by thd on 2017/8/1
 */
public class Main1 {
    public static void main(String[] args) {
        Scanner scanner = new Scanner(System.in);
        while (scanner.hasNext()) {
            int n = scanner.nextInt();
            scanner.nextLine();
            long max1 = 1;
            long max2 = 1;
            long max3 = 1;
            long min1 = 1;
            long min2 = 1;
            for (int i = 0; i < n; i++) {
                long num = scanner.nextLong();
                if (num > 0) {
                    if (num > max1) {
                        max3 = max2;
                        max2 = max1;
                        max1 = num;
                        continue;
                    } else if (num > max2) {
                        max3 = max2;
                        max2 = num;
                    } else if (num > max3) {
                        max3 = num;
                    }
                } else {
                    if (num < min1) {
                        min2 = min1;
                        min1 = num;
                    } else if (num < min2) {
                        min2 = num;
                    }
                }
            }
            if (min1 != 1 || min2 != 1) {
                if (min1 * min2 < max2 * max3) {
                    System.out.println(max2 * max3 * max1);
                } else {
                    System.out.println(min1 * min2 * max1);
                }
            } else {
                System.out.println(max2 * max3 * max1);
            }
        }
    }
}
复制代码

转载于:https://juejin.im/post/5c849db55188257b050d6aa1

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值