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,...)
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 求幸运数字 蓝桥杯试题,求解答!求算法!的主要内容,如果未能解决你的问题,请参考以下文章