swapLexOrder

给定一个字符串str和字符串对应的可以交换位置的下表数组pairs,求交换之后字典顺序最大的字符串(facebook笔试题).
- 题目可能说的不是很明了,看个例子就很清楚要做什么了
- 给定一个字符串str="abcd",可交换位置的下表数组为pairs=[[1,4],[3,4]],输出结果应该是swapLexOrder(str,pairs)="dbca"
- pairs=[[1,4],[3,4]]告诉我们可以交换的位置是14或者34之间,这样可以说1,3,4之间是可以相互交换位置的,然后据此对字符串操作,"cbda","cbad","dbac","dbca"所以交换之后的指定位置按字典顺序排序后的字符串为”dbca".

  • 验证代码(python)

    def swapLexOrder(string, pairs):
        elems = list(string)
        connected = []
        for pair in pairs:
            current_con_ind = -1
            to_delete_ind = []
            for j in range(len(connected)):
                if pair[0] in connected[j] or pair[1] in connected[j]:
                    if current_con_ind == -1:
                        connected[j].extend(pair)
                        connected[j] = sorted(list(set(connected[j])))
                        current_con_ind = j
                    else:
                        connected[current_con_ind].extend(connected[j])
                        to_delete_ind.append(j)
                        connected[current_con_ind].extend(pair)
                        connected[current_con_ind] = sorted(list(set(connected[current_con_ind])))
            for d in to_delete_ind:
                del connected[d]
            if current_con_ind == -1:
                connected.append(sorted(pair))
        print connected
        for indeces in connected:
            substring = []
            for index in indeces:
                substring.append(string[index-1])
            substring = sorted(substring, reverse=True)
            for i in range(len(indeces)):
                elems[indeces[i]-1] = substring[i]
        return ''.join(elems)
  • 提交代码(C++)

    std::string swapLexOrder(std::string str, std::vector<std::vector<int>> pairs) {
        std::vector<int>del;
        std::vector<std::set<int>>indeies;
        for(size_t i=0;i<pairs.size();i++){
            int flag=-1;
            for(size_t j=0;j<indeies.size();j++){
                if(indeies[j].count(pairs[i][0])||indeies[j].count(pairs[i][1])){
                    if(flag==-1){
                        indeies[j].insert(pairs[i][0]);
                        indeies[j].insert(pairs[i][1]);
                        flag=j;
                    }
                    else{
                        for(std::set<int>::iterator it=indeies[j].begin();it!=indeies[j].end();it++){
                            indeies[flag].insert(*it);
                        }
                        del.push_back(j);
                    }
                }
            }
            for(size_t k=0;k<del.size();k++){
                indeies.erase(indeies.begin()+del[k]-k);
            }
            if(flag==-1){
                std::set<int>oIndex;
                oIndex.insert(pairs[i][0]);
                oIndex.insert(pairs[i][1]);
                indeies.push_back(oIndex);
            }
            del.clear();
        }
        for(size_t i=0;i<indeies.size();i++){
            std::vector<char>subStr;
            for(std::set<int>::iterator it=indeies[i].begin();it!=indeies[i].end();it++){
                subStr.push_back(str[*it-1]);
            }
            sort(subStr.begin(),subStr.end());
            int j=subStr.size()-1;
            for(std::set<int>::iterator it=indeies[i].begin();it!=indeies[i].end();it++){
                str[*it-1]=subStr[j--];
            }
        }
        return str;
    }
  • refer

[1] https://codefights.com/interview-practice/task/5vXzdE9yzjsoMZ9sk

基于遗传算法的微电网调度(风、光、蓄电池、微型燃气轮机)(Matlab代码实现)内容概要:本文档介绍了基于遗传算法的微电网调度模型,涵盖风能、太阳能、蓄电池和微型燃气轮机等多种能源形式,并通过Matlab代码实现系统优化调度。该模型旨在解决微电网中多能源协调运行的问题,优化能源分配,降低运行成本,提高可再生能源利用率,同时考虑系统稳定性与经济性。文中详细阐述了遗传算法在求解微电网多目标优化问题中的应用,包括编码方式、适应度函数设计、约束处理及算法流程,并提供了完整的仿真代码供复现与学习。此外,文档还列举了大量相关电力系统优化案例,如负荷预测、储能配置、潮流计算等,展示了广泛的应用背景和技术支撑。; 适合人群:具备一定电力系统基础知识和Matlab编程能力的研究生、科研人员及从事微电网、智能电网优化研究的工程技术人员。; 使用场景及目标:①学习遗传算法在微电网调度中的具体实现方法;②掌握多能源系统建模与优化调度的技术路线;③为科研项目、毕业设计或实际工程提供可复用的代码框架与算法参考; 阅读建议:建议结合Matlab代码逐段理解算法实现细节,重点关注目标函数构建与约束条件处理,同时可参考文档中提供的其他优化案例进行拓展学习,以提升综合应用能力。
此项目旨在实现一个简易而实用的RFID智能门禁控制系统。采用经典的51系列单片机——STC89C52作为核心控制器,集成MFRC522射频识别模块来读取RFID卡片信息。用户界面通过128x64像素的LCD显示屏展示相关信息,同时配备了键盘用于密码的输入、验证及修改。此设计结合了RFID技术的高效率识别与单片机的强大控制能力,适用于学习、教学或小型安防项目。 资源包含 源代码:完整C语言编写的源程序,涵盖了RFID识别、密码验证逻辑、显示控制以及用户交互等功能模块。 原理图:详细展示了整个系统的电路连接,包括单片机、MFRC522模块、LCD12864屏幕、按键等组件的电气连接方式,便于理解和自制。 技术特点 RFID技术应用:通过MFRC522模块实现非接触式身份认证,提升门禁安全性与便捷性。 人机交互界面:利用LCD12864显示屏直观展示状态信息,并通过物理按键进行操作,增加了系统的易用性。 密码安全机制:支持用户密码的设定和更改,增强系统安全性。 51单片机编程:适合初学者和专业人士学习51单片机应用开发,尤其是嵌入式系统与物联网领域的实践。 使用指南 环境搭建:确保你有合适的IDE(如Keil uVision)安装以编译51单片机的C代码。 原理图分析:详细阅读原理图,了解各部件间的连接,这对于正确搭建硬件平台至关重要。 编译与上传:将提供的源代码编译无误后,通过编程器或ISP接口烧录到STC89C52单片机中。 硬件组装:根据原理图搭建电路,确保所有组件正确连接。 测试与调试:完成后进行功能测试,可能需要对代码或硬件做适当调整以达到最佳工作状态。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值