星期日, 九月 02, 2012

笨办法学R编程(6)

有时候用R来解一些Project Euler的题目会非常简单,今天就来三题连解(6、7、8)。题目就不再这里复述了,可以查看官方网站。用到函数和表达式大部分在前面都已经熟悉过了,不过还是会接触到一些新的函数。废话不多说直接上代码吧。

# Euler 6  
x <- 1:100
sum(x)^2 - sum(x^2)
 
# Euler 7 
 
n <- 0
i <- 1
m <- rep(0,10001)
while (n <10001) {
    if (findprime(i)) {
        n <- n +1 
        m[n] <- i}
    i <- i + 1
}
m[10001]
 
# 预备练习,熟悉一些字符串操作函数
text <- c('hello','world','I','love','code')
gsub('o',' ',text)
gsub('o','*',text)
gsub('o','',text)
 
(temp1 <-paste(text,collapse=' '))
paste(text,collapse='*')
paste(text,collapse='')
 
(temp2 <- strsplit(temp1," "))
class(temp2)
(temp3 <- unlist(strsplit(temp1," ")))
class(temp3)
 
# Euler 8 
 
web <- 'http://projecteuler.net/problem=8'
# 用readLines函数来抓取网页
raw <- readLines(web)
raw <- raw[54:73]
# 删除多余字符串
data <- gsub('<br />','',raw)
# 粘合成一个字符串
num <- paste(data,collapse='')
# 分割后转为数值向量
temp <- as.numeric(unlist(strsplit(num,'')))
 
p <- numeric()
for ( i in 1:(1000-4)) {
    p[i] <- prod(temp[i:(i+4)])
}
max(p)

第六题用R的向量化计算非常简单,第七题需要用到第二题中建立的findprime函数。第八题的解决是用字符串方法,先将那一长串数字作为字符串切开,再转为数值型向量,最后用循环求乘积。为了偷懒,是直接抓取的网页,没有输入那个长长的数字。

6 条评论:

  1. # Euler 6 的解法看起来…… 好直观 -,-
    跪求问博主有优化一点的方法可供学习么?

    回复删除
    回复
    1. 什么是优化一点的方法啊?

      删除
  2. 抓取网页的另一个代码:
    require(XML)
    url = "http://projecteuler.net/problem=8"
    dat = htmlTreeParse(url, useInternal = TRUE)
    temp = as.character(iconv(sapply(getNodeSet(doc = dat,
    path = "//p[@style='font-family:courier new;font-size:10pt;text-align:center;']"), xmlValue),
    from = 'utf-8', to = ''))

    回复删除
    回复
    1. 不错,顺便问下你的博客打不开啊

      删除
    2. 我的博客是:http://ruready.sinaapp.com

      删除
  3. 博主继续啊!喜欢你解决问题的思路,膜拜中!

    回复删除