会员可以在此提问,百战程序员老师有问必答
对大家有帮助的问答会被标记为“推荐”
看完课程过来浏览一下别人提的问题,会帮你学得更全面
截止目前,同学们一共提了 132495个问题
JAVA 全系列/第十一阶段:分布式RPC调用和分布式文件存储/Zookeeper 23057楼

代码:

class Array():
    def __init__(self,size=4):
        self.__size=size
        self.__item=[None]*size
        self.__length=0
    def __setitem__(self, key, value):
        self.__item[key]=value
    def __getitem__(self, key):
        return self.__item[key]
    def __iter__(self):
        for i in self.__item:
            yield i
class Heap():
    def __init__(self):
        self.item=Array(8)
        self.count=0
    def add(self,value):
        self.item[self.count]=value
        self.setup(self.count)
        self.count += 1
    def setup(self,index):
        if index>0:
            parent=int((index-1)/2)
            if self.item[parent]<self.item[index]:
                self.item[parent],self.item[index]=self.item[index],self.item[parent]
                self.setup(parent)
    def pop(self,index=0):
        if self.count<=0:
            return None
        else:
            value = self.item[0]
            self.count -= 1
            self.item[0] = self.item[self.count]
            self.item[self.count] = None
            self.setdown(0)
            return value
    def setdown(self,index):
        left=index*2+1
        right=index*2+2
        largest=index
        if right<self.count:
            if self.item[largest]<self.item[right] and self.item[right]>self.item[left]:
                largest=right
            elif self.item[largest]<self.item[right] and self.item[right]<self.item[left]:
                largest=left
            elif self.item[largest]>self.item[right] and self.item[largest]<self.item[left]:
                largest=left
        elif left<self.count:
            if self.item[left]>self.item[largest]:
                largest=left
        if largest !=index:
            self.item[largest],self.item[index]=self.item[index],self.item[largest]
            self.setdown(largest)
heap=Heap()
heap.add(10)
heap.add(15)
heap.add(20)
# heap.pop(20)
heap.pop(10)
for i in heap.item:
    if i:
        print(i)

运行结果:

屏幕截图 2021-04-02 163046.png

老师请问一下,为什么我最大堆删除10以后,再打印,结果还是会显示10?我不是已经把10删除了吗?那么这样结果不应该是20和15吗?

Python 全系列/第十六阶段:数据结构与算法/算法与数据结构(旧) 23059楼

flask_shop.zip

vue_shop.zip

老师   求助!!!  

我前端可以拿到后端的数据   但是增加数据   修改数据都不行   运行代码也不报错 

我找了半天    也改了  但是都不行   发送请求之前验证数据是否规范是false  我觉得可能是这里的错误  

希望老师帮忙!!!


Python 全系列/第十阶段:Flask百战电商后台项目/Flask百战电商后台项目 23061楼
Python 全系列/第一阶段:Python入门/编程基本概念 23063楼
Python 全系列/第一阶段:Python入门/编程基本概念 23064楼
JAVA 全系列/第十一阶段:分布式RPC调用和分布式文件存储/Zookeeper 23066楼
Python 全系列/第四阶段:函数式编程和核心特性/生成器和装饰器 23068楼
JAVA 全系列/第十一阶段:分布式RPC调用和分布式文件存储/Zookeeper 23070楼

课程分类

百战程序员微信公众号

百战程序员微信小程序

©2014-2025百战汇智(北京)科技有限公司 All Rights Reserved 北京亦庄经济开发区科创十四街 赛蒂国际工业园
网站维护:百战汇智(北京)科技有限公司
京公网安备 11011402011233号    京ICP备18060230号-3    营业执照    经营许可证:京B2-20212637