Java/C 求幸运数字 蓝桥杯试题,求解答!求算法!

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Java/C 求幸运数字 蓝桥杯试题,求解答!求算法!相关的知识,希望对你有一定的参考价值。

最后剩下的序列类似:

1, 3, 7, 9, 13, 15, 21, 25, 31, 33, 37, 43, 49, 51, 63, 67, 69, 73, 75, 79, ...

本题要求:

输入两个正整数m n, 用空格分开 (m < n < 1000*1000)
程序输出 位于m和n之间的幸运数的个数(不包含m和n)。

例如:
用户输入:
1 20
程序输出:
5

例如:
用户输入:
30 69
程序输出:
8

资源约定:
峰值内存消耗(含虚拟机) < 64M
CPU消耗 < 2000ms

请严格按要求输出,不要画蛇添足地打印类似:“请您输入...” 的多余内容。

所有代码放在同一个源文件中,调试通过后,拷贝提交该源码。
注意:不要使用package语句。不要使用jdk1.6及以上版本的特性。
注意:主类的名字必须是:Main,否则按无效代码处理。
标题:幸运数

幸运数是波兰数学家乌拉姆命名的。它采用与生成素数类似的“筛法”生成。

首先从1开始写出自然数1,2,3,4,5,6,....

1 就是第一个幸运数。
我们从2这个数开始。把所有序号能被2整除的项删除,变为:

1 _ 3 _ 5 _ 7 _ 9 ....

把它们缩紧,重新记序,为:

1 3 5 7 9 .... 。这时,3为第2个幸运数,然后把所有能被3整除的序号位置的数删去。注意,是序号位置,不是那个数本身能否被3整除!! 删除的应该是5,11, 17, ...

此时7为第3个幸运数,然后再删去序号位置能被7整除的(19,39,...)

参考技术A package com.sise.hhz.LQB;
import java.util.Iterator;
import java.util.LinkedList;
import java.util.ListIterator;
import java.util.Scanner;
public class LuckyNumber

static Integer count = 0;
static Integer index = 1;
public static void getLuckyNum(LinkedList al, Integer min, Integer max, Integer luckyNum)

ListIterator lt = al.listIterator();
Integer maxSize = al.size();
boolean judge = true;
for(Integer i = 1; i <= maxSize; i++)

lt.next();
if(i % luckyNum == 0)

judge = false;
lt.remove();


if(judge)

lt = al.listIterator();
while(lt.hasNext())

if((Integer)lt.next() > min)

count =al.size() - lt.previousIndex();
return;


return;

luckyNum = (Integer)al.get(index++);
getLuckyNum(al, min, max, luckyNum);

public static void main(String []src)

LinkedList al = new LinkedList();
Integer min = 0;
Integer max = 0;
Scanner sn = new Scanner(System.in);
min = sn.nextInt();
max = sn.nextInt();
for(int i = 1; i < max; i++)

al.add(i);

getLuckyNum(al, min, max, 2);
System.out.println(count);

参考技术B 真是中国特色的编程题 参考技术C 给点积分吧本回答被提问者采纳

蓝桥杯-试题B:字串数字

试题B:字串数字

答案:3725573269
注意:就是进制转换问题,26进制转换为10进制。

public class Main {
    public static String to(String s, int n){
        long res = 0 ;
        for(int i=0; i<n; i++){
             res += (long)((s.charAt(i) - 'A' + 1) * Math.pow(26, n-i-1)) ;
        }
        return String.valueOf(res) ;
    }
    public static void main(String[] args) {
        String s = "LANQIAO" ;
        System.out.println(to(s, s.length()));
    }
}

以上是关于Java/C 求幸运数字 蓝桥杯试题,求解答!求算法!的主要内容,如果未能解决你的问题,请参考以下文章

蓝桥杯往年本科java试题。。。 非常感谢

第六届蓝桥杯大赛个人赛省赛java b组试题 三羊献瑞怎么解

第十届蓝桥杯大赛软件类省赛Java研究生组-题解

第十四届蓝桥杯大赛软件赛省赛JavaB组解析

蓝桥杯 ALGO-985 幸运的店家(贪心)

蓝桥杯 历届试题 数字三角形