首页 > 其他 > 详细

njuoj 递归查询字符串

时间:2019-11-16 00:56:34      阅读:164      评论:0      收藏:0      [点我收藏+]

技术分享图片

 

 思路:每次将pos映射到对称区间的相应位置。直到达到[1,5]区间

其中需要注意的是,需要找到$的分布规律。单独处理

package com.company.dp;

import java.util.ArrayList;
import java.util.List;
import java.util.Scanner;

public class 递归查询子字符串 {
    public static void main(String[] args) {
        Scanner scanner=new Scanner(System.in);
        int case_num=Integer.parseInt(scanner.nextLine());
        for (int i = 0; i < case_num; i++) {
            long pos=Long.parseLong(scanner.nextLine());
            char res=getNum(pos);
            System.out.println(res);
        }
        scanner.close();
    }

    private static char getNum(long pos) {
        long[] s=new long[50];
        s[0]=5;
        for (int i = 1; i < s.length; i++) {
            s[i]=s[i-1]*2+i;
            
        }
        for (int i = 0; i < s.length; i++) {
            System.out.println(s[i]);
        }

        String str0="12345";

        while(pos>5){
            for (int i = 1; i < s.length; i++) {
                if(pos>=s[i-1]&&pos<=s[i]){

                    if(2*pos-s[i]>=0&&2*pos-s[i]<=i)return ‘$‘;
                    pos=s[i]-pos+1;
                    break;
                }

            }

        }
        return str0.charAt(((int) pos)-1);
        
    }

}

 

njuoj 递归查询字符串

原文:https://www.cnblogs.com/geck/p/11870271.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!