【百度研发岗实习笔试】

第二题要求构造一个包含n个回文子串的仅由red三个字母组成的字符串。

此题是一个思维题,这里提供一个构造思路。由m个"r"连续构成的字符串,将会有$n*(n+1)/2$个回文子序列,而"red"只能够组成3个回文子序列,那么先对连续的"r"排列,直到最后一个"r"排列后,字符串不能允许更多的"r"排进来。然后就将"edr"排进来,直到满足n个回文子串个数。

// 题目: 有且只有"r" "e" "d"三个字母,给定一个数字n,要求输出由3个字母所组成的包含n个回文串的
// 字符串

// redred

package main 

import "fmt"

func main(){
    var n int 
    fmt.Scanf("%d" , &n)
    
    count := 0 
    for i :=0 ; i < n ; i++{
        if (i+1)*i/2 > n{
            count = i - 1 
            break
        }
    }
    s := ""
    for i:=0 ; i < count ; i++{
        s += "r"
    }
    res := n - (count + 1)*count/2
    for i:=0 ; i<res ; i++{
        if i%3 == 0{
            s += "e"
        }else if i%3 == 1{
            s += "d"
        }else {
            s += "r"
        }
    }
    fmt.Println(s)
}

全部评论
快结束的时候,才想出来这个思路了😭
点赞 回复 分享
发布于 2023-03-14 00:56 上海
m了学习一下
点赞 回复 分享
发布于 2023-03-15 16:09 山东
感谢大佬分享
点赞 回复 分享
发布于 2023-03-15 16:24 四川
这个只能过40%吧,我也是这个思路
点赞 回复 分享
发布于 2023-04-13 08:38 贵州

相关推荐

new和malloc的区别?c++里new了数组怎么释放?32位系统的指针变量占多大字节?int*呢?空类呢?c++多态?为什么需要虚析构?虚析构实现原理?c++可以不写构造函数吗?编译器默认除了构造还会有什么?深拷贝和浅拷贝区别?智能指针哪个c++版本引入的,作用?用过哪些容器?项目里用了哪些容器?为什么用qlist?qmap什么是key?模板的好处?什么时候会用?设计模式了解哪些?自己写过吗?单例模式怎么写?单例要返回非静态指针类型怎么弄?队列和栈的区别?osi七层以及相应协议?网络层的协议?应用层?一些项目问题...网络加密算法知道哪些?tcp的三次握手四次挥手回收写过吗?写服务器基本模...
AI牛可乐:哇,你分享了好多面试经验呢,听起来你准备得很充分呢!👍 关于你提到的技术问题,我来帮你解答一下吧: 1. `new` 和 `malloc` 的区别?`new` 会自动调用构造函数,而 `malloc` 只负责分配内存。`new` 数组释放时用 `delete[]`,比如 `delete[] myArray;`。 2. 在32位系统中,指针变量通常占4个字节,`int*` 也是如此。 3. 空类的实例通常占1个字节,但具体实现可能不同。 4. C++多态允许我们通过基类指针或引用来调用派生类的函数。需要虚析构是因为基类指针可能指向派生类对象,不使用虚析构可能导致派生类析构函数不被调用。 5. 如果不写构造函数,编译器会提供一个默认构造函数。默认构造函数会进行成员变量的默认初始化。 6. 深拷贝和浅拷贝的区别在于,深拷贝会复制对象的所有字段,包括指向的内存内容;浅拷贝只复制对象的字段值,不复制指向的内存内容。 7. 智能指针是在C++11版本引入的,用于自动管理内存,防止内存泄漏。 8. 常用的容器有 `vector`、`list`、`map` 等。具体使用哪个容器取决于项目需求。 关于你问的其他问题,我简单回答一下: - `QList` 通常用于需要频繁插入和删除的场景。 - `QMap` 的 `key` 是映射表中的键值。 - 模板的好处是提高代码复用性,减少代码冗余。 - 设计模式有很多种,比如单例模式、工厂模式等。单例模式可以通过静态成员函数实现。 现在,悄悄告诉你一个小秘密,点击我的头像,我们可以私信聊天哦~🎉 那么,你平时在项目中都用过哪些容器呢?有没有什么特别的经验或者技巧可以分享的呢?😊
点赞 评论 收藏
分享
评论
7
15
分享

创作者周榜

更多
牛客网
牛客企业服务