当前位置: 首页 > news >正文

dfs之有重复字符串的排列组合

https://leetcode.cn/problems/permutation-ii-lcci/description/

■ 题目描述

考古问题,假设以前的石碑被打碎成了很多块,每块上面都有一个或若干个字符,请你写个程序来把之前石碑上文字可能的组合全部写出来,按升序进行排列。

示例1   输入输出示例仅供调试,后台判题数据一般不包含示例

输入

3

a b c

输出

abc

acb

bac

bca

cab

cba

示例2   输入输出示例仅供调试,后台判题数据一般不包含示例

输入

3

a b a

输出

aab

aba

baa

/*** Note: The returned array must be malloced, assume caller calls free().*/void Swap(char *a, char *b)
{char t;t = *a;*a = *b;*b = t;
}/* 进行递归的函数 */
int DFS(char *temp, int len, int k, char **res, int *returnSize)
{// k是当前要插入的位置的下表,k之前的都已经插入完成了char used[27]; //表示出现过的字母int j;int userdi = 0;//递归结束的条件,大循环下表来到最后一个元素,无需操作if (k >= len - 1) {strcpy(res[(*returnSize)++], temp);return 0;}for (int i = k; i < len; i++) {if (userdi == 0) {used[userdi++] = temp[i];} else {for (j = 0; j < userdi; j++) {if (used[j] ==  temp[i]) {break;}}if (j >= userdi) {used[userdi++] = temp[i];} else {continue;}}Swap(&temp[i], &temp[k]);DFS(temp, len, k + 1, res, returnSize);Swap(&temp[i], &temp[k]);}return 0;
}char** permutation(char* S, int* returnSize){char **res;int resNum, len = strlen(S);int i, j, k;char *temp = malloc(sizeof(char) * (len + 2));strcpy(temp, S);res = malloc(sizeof(char *) * 1000);for (i = 0; i < 1000; i++) {res[i] = malloc(sizeof(char) * len + 1);}resNum = 0;k = 0;*returnSize = 0;DFS(temp, len, k, res, returnSize);return res;
}

http://www.lryc.cn/news/134352.html

相关文章:

  • Java之抽象类
  • “无Internet连接但是可以上网” 解决全流程
  • VS2022 CMake报错解决小结
  • java之webservice_aegis.xml学习
  • 总结 TCP 协议的相关特性
  • 不负众望~历时4年修炼,这本册子终于成书了(文末赠书)
  • 【校招VIP】java语言考点之垃圾回收算法
  • juc概述和Lock接口
  • 图像降采样的计算原理:F.interpolate INTER_AREA
  • 云上的甜蜜早安:腾讯云云函数助力PHP打造女友专属每日推送
  • Javaweb基础学习(3)
  • 使用在 Web 浏览器中运行的 VSCode 实现 ROS2 测程法
  • 快速学习GO语言总结
  • 尚硅谷宋红康MySQL笔记 10-18
  • Java 面试题--SpringBoot篇
  • GitKraken 详细图文教程
  • ubuntu20.04 root用户下使用中文输入法——root用户pycharm无法用中文输入法问题
  • FastDFS与Nginx结合搭建文件服务器,并实现公网访问【内网穿透】
  • 嵌入式蓝海变红海?其实是大浪淘沙!
  • 【附安装包】Solid Edge2023安装教程最强CAD选择
  • 494. 目标和
  • C++学习笔记总结练习:C++编译过程详解
  • 嵌入式设备应用开发(qt界面开发)
  • pytest结合Excel实现接口自动化
  • 【LLM数据篇】预训练数据集+指令生成sft数据集
  • WebDAV之π-Disk派盘 + 一羽记帐
  • ChatGPT:记一次超复杂的KVM桌面系统连接问答记录
  • python-docx把dataframe表格添加到word文件中
  • Web AP—BOM 浏览器对象模型
  • Flink分流,合流,状态,checkpoint和精准一次笔记