`

用python解一道奥数题(小学三年级)

阅读更多
今天在谢老师的blog上看到她小孩的一道奥数作业(难倒了N个硕士和博士的三年级奥数题),题目如下:

一个六位数,分别用2,3,4,5,6乘它,得到的五个新数仍是由原数中的六个数字组成,只是位置不同,则此六位数是多少?

顺手用python写了个解法:
python 代码
 
  1. def makeSet(num):  
  2.     tmp = set()  
  3.     for i in xrange(1,7):  
  4.         item = list(set(str(num*i)))  
  5.         item.sort()  
  6.         item = "".join(item)  
  7.         tmp.add(item)  
  8.     return tmp  
  9.   
  10. for i in xrange(100000,1000000):  
  11.     if len(makeSet(i))==1:  
  12.         print i  
  13.         break  
  14.   
  15. 输出结果为142857。  
分享到:
评论
17 楼 marshluca 2009-11-13  

def sort(x,i)
   return (x*i).to_s.split("").sort
end

for x in 100000...1000000
  tmp = sort(x,1)
  if sort(x,2)==tmp and sort(x,3)==tmp and sort(x,4)==tmp and sort(x,5)==tmp and sort(x,6)==tmp
    puts x
  end
end

16 楼 jamesqiu 2009-10-11  
写了个java的解:

void 小学奥数() {
L: for (int i = 111111; i < 1000000/6; i++) {
String si = set(i);
List<String> ss = Arrays.asList(set(i*2), set(i*3), set(i*4), set(i*5), set(i*6));
for (String s : ss) {
if (!s.equals(si)) continue L;
}
System.out.printf("i=%d (i*2=%d, i*3=%d, i*4=%d, i*5=%d, i*6=%d) \n", i, i*2, i*3, i*4, i*5, i*6);
   }
}

// 数n的所有数字的排序字符串
String set(int n) {
char[] ca = (""+n).toCharArray();
Arrays.sort(ca);
return new String(ca);
}
15 楼 chyichin 2008-12-29  
笨笨狗 写道

chyichin 写道
你好 我想请教你一个问题 我复制你的代码去运行 为什么报错呢? for i in xrange(100000,1000000):&amp;nbsp;&amp;nbsp; &amp;nbsp;&amp;nbsp;&amp;nbsp; if len(makeSet(i))==1:&amp;nbsp;&amp;nbsp; &amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; print i&amp;nbsp;&amp;nbsp; &amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; break SyntaxError: invalid syntax 错误指向 for变为粉红色的底 我是用Python Shell粘贴运行你的那代码 是这样吗? 或许是复制过去缩进乱了的问题,你可以用IDLE试试……

你好,IDLE 我复制了之后 回车就报错“SyntaxError: invalid syntax”
嗯 不会用这个工具
14 楼 笨笨狗 2008-12-25  
chyichin 写道

你好 我想请教你一个问题 我复制你的代码去运行 为什么报错呢? for i in xrange(100000,1000000):&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; if len(makeSet(i))==1:&nbsp;&nbsp; &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; print i&nbsp;&nbsp; &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; break SyntaxError: invalid syntax 错误指向 for变为粉红色的底 我是用Python Shell粘贴运行你的那代码 是这样吗?



或许是复制过去缩进乱了的问题,你可以用IDLE试试……
13 楼 chyichin 2008-12-24  
你好 我想请教你一个问题
我复制你的代码去运行 为什么报错呢?
for i in xrange(100000,1000000):  
    if len(makeSet(i))==1:  
        print i  
        break
SyntaxError: invalid syntax
错误指向 for变为粉红色的底


我是用Python Shell粘贴运行你的那代码 是这样吗?
12 楼 chyichin 2008-12-24  
python看起来有点像vbs呵呵 刚学python听说速度很快
11 楼 meteoric_cry 2008-08-30  
 俺用JS写了一个,得到的结果与你一样。。。。
嘻嘻。。。。:) HOHO。。
不过我读你的题目就读了N久了,因为你“一个六位数,分别用2,3,4,5,6乘它,得到的五个新数仍是由原数中的六个数字组成”一个六位数乘以2,3,4,5,6怎么会得到五个新数呢,应该是说得到的六个数还是原来六个数组成滴!!!!!不多说了,看结果就知道了
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
 <HEAD>
  <TITLE> New Document </TITLE>
  <META NAME="Generator" CONTENT="EditPlus">
  <META NAME="Author" CONTENT="ZhangYi">
  <META NAME="Keywords" CONTENT="">
  <META NAME="Description" CONTENT="">
  <meta http-equiv="Content-Type" content="text/html;charset=utf-8">
  <style type="text/css">
	
  </style>

  <script type="text/javascript">
	function isEqual(str1,str2) {
		var len1 = str1.length;
		var len2 = str2.length;
		//alert(typeof str1+"\n"+typeof str2)
		if(len1 != len2) return false;
		
		var temparr = str1.split("");
        var pos = -1;
	
		for (var i=0;i<len1;i++ )
		{	
			var rspos = str2.indexOf(temparr[i]);			
			if(rspos != -1) {
				if(pos != rspos) {
					pos = rspos;
					continue;
				}else {
					return false;
				}				
			} else {
				return false;
			}
		}
		return true;
	}

	function makeSet(num) {		
		var temp = num.toString();
		for (var i=2;i<7;i++)
		{
			var newNum = (i*num).toString();
			
			if(isEqual(temp,newNum)) {
				continue;
			}
			 else {
				return false;
			}
		}
		return true;
	}
	
	for (var i=100000;i<1000000 ;i++ )
	{
		if(makeSet(i)) {
			alert(i);
			break;
		}
	}
  </script>
 </HEAD>

 <BODY>
    
 </BODY>
</HTML>

10 楼 笨笨狗 2008-04-17  
引用
今天给tony看那个仿google导航图标的例子, 他一下子认出是你, 哈哈, 原来是校友啊!


呵呵,师哥好,俺是0111的呢,以后常联系哦,加你链接得了:)
9 楼 danielking 2008-04-16  
今天给tony看那个仿google导航图标的例子, 他一下子认出是你, 哈哈, 原来是校友啊!
8 楼 danielking 2008-04-16  
没人用人脑去解这个题吗?
7 楼 duka 2008-03-29  
算是小小及格了.hehe
c = []
num5 = 2,3,4,5,6
for x in xrange(100000,1000000):
    for i1 in num5:
        i2 = list(str(i1*x))
        i2.sort()
        c.append(i2)
    if c.count(c[0]) == len(num5):
        print x
        break
    c = []
6 楼 charka 2007-09-07  
(5)中有一行错了,应该是:p*3=?w =>(p,w)=(7,1)|(4,2)|(8,4)|(5,5)
这个给三年级的学生讲明白也不太容易,有没有更简单的解法?
5 楼 charka 2007-09-07  
昨晚没睡好,用呓语言得到的解法
设 x=abcdef;
(1)
   6x是六位数 => a=1
(2)
   x*[1,2,3,4,5,6]得到的六位数由abcdef组成
   =>f*[1,2,3,4,5,6]=[a,b,c,d,e,f];a=1
   =>f*3=?1
   =>f=7
(3)
   x=1bcde7
   7*[1,2,3,4,5,6]的个位=[7,4,1,8,5,2]=[a,b,c,d,e,f]
(4)
   3x=????u1; 6x=????v2=>(u,v)=(2,4)|(4,8)|(7,4)
   u=2;e7*3=?u1=>e*3=?0,与(3)矛盾
   u=4; e7*3=?u1 =>e*3=?2 =>e=4 => x=1bcd47;2x=????94 => e!=4
   u=7; e7*3=?u1 => e*3=?5 =>e=5
   ==>>e=5
(5)
x=1bcd57 =>
    2x=???p14=> p!=[1,4]
    4x=???q28 => q!=[2,8]
    6x=???w42 => w!=[4,2]
    p*2=?q => (p,q) =(2,4)|(4,8)|(7,4)
    p*3=?w =>(p,q)=(7,1)|(4,2)|(8,4)|(5,5)
==>p=7 =>d*2+1=?7 =>d=8
(6) x=1bc857
   b=2;c=4 => 2x=249714 矛盾
==> b=4,c=2
(7)
    x=142857
4 楼 ms99ster 2007-07-12  
谢老师的blog上还有另外的一道奥数题

“足球*篮球=踢足球1”,在上面的乘法算式中,不同的汉字代表不同的数学,相同的汉字代表相同的数学。其中,乘积是一个个位为1的四位数,那么“足球”和“篮球”这两个两位数的和是多少?

结果好像是69*39=2691
用手算出来的,也没有看懂上面的程序
3 楼 Lich_Ray 2007-07-12  
程序已经彻底没意义了。这个问题我已经用数学方法证明出来了。
2 楼 笨笨狗 2007-07-12  
to Lich_Ray:

的确,最近看ruby,python的range给搞混淆了,而且,现在的版本用xrange更有效率,已经改过了。哈哈……
我对FP不是很熟悉,不过看样子很强大,但是这种问题,用常规的写法貌似普通人理解起来要容易得多。
1 楼 Lich_Ray 2007-07-11  
我也写了一个。本来想写成一句话的,后来发现用 Python 玩儿 FP 简直是受罪!Scheme 中的一句话被迫变成了这么多:
def list_equ (ls):
	for cond in map(lambda x: ls[0] == x, ls):
		if not cond:
			return False
	return True

def sort (ls):
	ls.sort()
	return ls

def test_num (num):
	return list_equ(map(lambda x: reduce(lambda i,j: i+j, sort(list(str(x * num)))), range(2,7)))

# 这招只能在 Haskell 中用
#def give_rst ():
#	return filter(test_num, range(100000,1000000))
	
# 今天太生气了,干脆用这个了:
 for i in range(100000,1000000):
     if (test_num(i)):
             print i
             break

PS: 楼上对于 range() 函数边界的理解有误。range(1,6) 的结果是 [1,2,3,4,5] 而不是 [2,3,4,5,6]。应该用 range(2,7),虽然结果不变。

相关推荐

    中小学数学题程序_instance62k_python题_Python解数学题_Python解奥数题_python解初中题_

    在Python编程领域,解决中小学数学题,包括奥数题和初中数学题,是一种常见的实践,旨在提高编程技能和逻辑思维能力。"instance62k_python题"可能指的是一个包含62000个数学问题的实例集合,这些题目涵盖了从小学到...

    用python编写的一些奥数题.pdf

    以下是一些使用Python编写的典型奥数题及其解决方案: 1. **计算连续整数之和**: 这个例子展示了如何计算1到113的所有数字之和。使用`for`循环遍历1到113的整数,将每个数字累加到变量`sum`中。最后,打印出总和...

    Python期末试卷试题_三年级数学期末试卷题

    Python期末试卷试题

    python计算机二级题库(附带答案)

    python计算机二级题库(附带答案)python计算机二级题库(附带答案)python计算机二级题库(附带答案)python计算机二级题库(附带答案)python计算机二级题库(附带答案)python计算机二级题库(附带答案)python...

    Python自动生成小学三年级口算题及答案保存到Excel文件

    概要:通过Python自动生成小学三年级口算题,保存到Excel文件,包含两个sheet,题目和答案。 适用人群:小学3年纪孩子家长 使用场景及目标:通过该脚本可以自动生成小学三年级口算题,口算题包括综合计算、小数运算...

    python 破解 wifi密码

    python 实现wifi密码的暴力破解。

    第01课-初识Python-小学五年级兴趣课

    到了2018年,根据TIOBE编程语言排行榜,Python在全球编程语言中排名第三。 计算机与程序设计: 计算机是根据指令操作数据的设备,它具有可编程性,可以根据预设的程序来处理数据。程序设计(编程)则是设计、编制、...

    Python面试选择题题库

    自己整理一些大厂的面试题题库,都是一些常见的题目,希望能给大家提供帮助,题库分为3个部分这是第二部分

    小学数学口算题是一款利用Python开发了一套自动生成小学生口算题的小应用.rar

    孩子上小学一年级了,加减乘除的口算就要开始练习了,估计老师肯定会让家长出题,所以提前准备一下,利用Python开发了一套自动生成小学生口算题的小应用。而且今天是程序员节,撸200行代码庆祝一下。:) 程序核心...

    2022年NOC软件创意编程(学而思赛道)选拔赛小学高年级组python,包含答案详细解析.pdf

    【2022年NOC软件创意编程(学而思赛道)选拔赛小学高年级组Python】是一项旨在激发小学生对编程兴趣和创新能力的比赛。比赛涵盖了Python编程的基础知识和应用技能,旨在培养学生的逻辑思维和问题解决能力。在这个...

    Python 海龟绘图 120 题

    Python 海龟绘图 120 题 ...Python 海龟绘图 120 题涵盖了 turtle 基本命令、绘制基本图形、循环命令、综合应用、turtle 对象的使用等方面的知识点,为学习 Python 海龟绘图提供了prehensive 指南。

    第14届蓝桥杯Python省赛真题-大学B组

    第14届蓝桥杯Python省赛真题-大学B组 第14届蓝桥杯Python省赛真题-大学B组 第14届蓝桥杯Python省赛真题-大学B组 第14届蓝桥杯Python省赛真题-大学B组 第14届蓝桥杯Python省赛真题-大学B组 第14届蓝桥杯Python省赛...

    Python期末考试题 Python程序设计考试题 Python编程期末测评题目 共22页

    Python期末考试题通常会涵盖多个方面,旨在测试学生对Python编程基础的掌握程度,包括语法、数据结构、控制流、函数、错误处理等核心概念。 一、选择题: 1. 表达式`'%d%%%d' %(3 / 4, 3 % 4)`的值是判断浮点数与...

    Python基础训练100题(带答案).docx

    这篇文档提供了100个Python基础训练题,旨在帮助学习者巩固Python3的基本语法和概念。这些实例覆盖了Python中的多种核心概念,包括数字操作、字符串处理、循环、条件判断、函数、类、模块以及一些进阶特性。 例如,...

    Python经典面试题-总结

    Python经典面试题 Python经典面试题 python面试题 python 面试题 Python经典面试题 Python经典面试题 python面试题 python 面试题 Python经典面试题 Python经典面试题 python面试题 python 面试题 Python经典面试题 ...

    Python训练100题_Python基础训练100题_

    "Python训练100题"是一份专为新手设计的资源,旨在帮助学习者巩固和提升Python编程基础。这100道题目覆盖了Python语言的核心概念,包括语法、数据类型、控制结构、函数、模块、错误与异常处理等多个方面。 1. **...

    python中级试题(含答案)_python选择题及答案

    python中级试题(含答案)

    python 基础程序100题

    【Python基础程序100题】是一套专为Python初学者设计的练习集,旨在通过每日5题的方式,持续20天,系统性地提升学习者的编程能力。这个练习计划覆盖了Python语言的基础到进阶知识,是巩固理论并提高实践操作技能的...

    python练习题100题.zip_KBL_Python 练习册_Python初学习题_python习题_python计算题

    这份"python练习题100题.zip"压缩包提供了一套完整的Python学习资源,专为Python初学者设计,涵盖了从基础语法到实际应用的各种练习题,旨在帮助你扎实地掌握Python编程技能。 一、Python基础语法练习 在Python初学...

    Python期末试题题库完整.pdf

    Python语言的注释使用“#”符号,单行注释使用“#”,多行注释使用三引号“"""或'''」。 2. Python变量和数据类型 Python语言支持多种数据类型,包括整数(int)、浮点数(float)、字符串(str)、列表(list)、元组...

Global site tag (gtag.js) - Google Analytics