2018-03-26-马路上的路灯

1、问题描述


思路:

首先设一个装数据的总list,元素也是list,每个元素是表示一个区域的起始点和终止点的坐标。

其次总list按每个元素的终止点为升序排序依据,排好序;

然后比较第一个元素的终止点和第二个元素的起始点,要是第一个元素的终止点>第二个元素的起始点时,就合并这两个list赋值给第一个元素,并且对这个新的list进行排序。同时,在总list中移除被合并的list元素,总list的长度len()-1,进行下一轮的比较,还是从合并后的那个新元素下标开始。要是第一个元素的终止点<第二个元素的起始点时,比较下标+1,进行下一轮的比较。

最后,对每个元素的终止点-起始点+1=移走的路灯,加起来所有移走的路灯=s。(m+1)(即是总路灯数包括0处的灯)-s。


代码:
if __name__=='__main__':
    mn=raw_input()
    m=int(mn.split()[0])
    n=int(mn.split()[1])
    res=[]
    h=[]
    ret=[]
    for i in range(n):
        a,b=raw_input().split()
        res.append([int(a),int(b)])
    ret=sorted(res, key=lambda x:x[1])
    k=len(ret)
    i=0
    while i<k-1:
        if ret[i][-1]>ret[i+1][0]:
            ret[i]=ret[i+1]+ret[i]
            ret[i].sort()
            ret.remove(ret[i+1])
            k=k-1
            i=i
        else:
            i=i+1
    for i in range(len(ret)):
        h.append(ret[i][-1]-ret[i][0]+1)
    s=sum(h)
    print (m+1)-s

2、知识补充:

排序:将list中的元素进行排序,不改变原list。

Python sorted() 函数:

描述
sorted() 函数对所有可迭代的对象进行排序操作。
sort 与 sorted 区别:
sort 是应用在 list 上的方法,sorted 可以对所有可迭代的对象进行排序操作。
list 的 sort 方法返回的是对已经存在的列表进行操作,而内建函数 sorted 方法返回的是一个新的 list,而不是在原来的基础上进行的操作。
语法
sorted 语法:
sorted(iterable[, cmp[, key[, reverse]]])
参数说明:
iterable -- 可迭代对象。
cmp -- 比较的函数,这个具有两个参数,参数的值都是从可迭代对象中取出,此函数必须遵守的规则为,大于则返回1,小于则返回-1,等于则返回0。
key -- 主要是用来进行比较的元素,只有一个参数,具体的函数的参数就是取自于可迭代对象中,指定可迭代对象中的一个元素来进行排序。
reverse -- 排序规则,reverse = True 降序 , reverse = False 升序(默认)。
返回值
返回重新排序的列表。
实例

以下实例展示了 sorted 的使用方法:

>>>a = [5,7,6,3,4,1,2]
>>> b = sorted(a)       # 保留原列表
>>> a 
[5, 7, 6, 3, 4, 1, 2]
>>> b
[1, 2, 3, 4, 5, 6, 7]
 
>>> L=[('b',2),('a',1),('c',3),('d',4)]
>>> sorted(L, cmp=lambda x,y:cmp(x[1],y[1]))   # 利用cmp函数
[('a', 1), ('b', 2), ('c', 3), ('d', 4)]
>>> sorted(L, key=lambda x:x[1])               # 利用key
[('a', 1), ('b', 2), ('c', 3), ('d', 4)]
 
 
>>> students = [('john', 'A', 15), ('jane', 'B', 12), ('dave', 'B', 10)]
>>> sorted(students, key=lambda s: s[2])            # 按年龄排序
[('dave', 'B', 10), ('jane', 'B', 12), ('john', 'A', 15)]
 
>>> sorted(students, key=lambda s: s[2], reverse=True)       # 按降序
[('john', 'A', 15), ('jane', 'B', 12), ('dave', 'B', 10)]
>>>



3、别人家的算法代码:

def func():
    while 1:
        initVal = raw_input()
        if initVal != '':
            m = int(initVal.split()[0])
            n = int(initVal.split()[1])
            s = set()
            for i in range(n):
                rowVal = raw_input()
                left = int(rowVal.split()[0])
                right = int(rowVal.split()[1])
                for j in range(left, right + 1):
                    s.add(j)
            print s
            print m + 1 - len(s)
        else:
            continue

if __name__ == '__main__':
    func()

思路:

人家用的是set,去重的性质。

运行结果:


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值