剑指OFFER之字符串的排列(九度OJ1369)
时间:2022-04-22
本文章向大家介绍剑指OFFER之字符串的排列(九度OJ1369),主要内容包括题目描述:、解题思路:、全部代码:、基本概念、基础应用、原理机制和需要注意的事项等,并结合实例形式分析了其使用技巧,希望通过本文能帮助到大家理解应用这部分内容。
题目描述:
输入一个字符串,按字典序打印出该字符串中字符的所有排列。例如输入字符串abc,则打印出由字符a,b,c所能排列出来的所有字符串abc,acb,bac,bca,cab和cba。
输入:
每个测试案例包括1行。
输入一个字符串,长度不超过9(可能有字符重复),字符只包括大小写字母。
输出:
对应每组数据,按字典序输出所有排列。
样例输入:
abc
BCA
样例输出:
abc
acb
bac
bca
cab
cba
ABC
ACB
BAC
BCA
CAB
CBA
解题思路:
这道题要注意两个问题:
第一个是重复字母,第二个是按字典顺序。
重复字母我们在进行交换的时候直接跳过就可以了,按字典顺序,这个就需要我们进行排列了。
排列使用冒泡排序:
void bubbleSort(char *arr,int begin,int length){
int i,j;
for(i=begin;i<length;i++){
for(j=i+1;j<length;j++){
if(arr[i]>arr[j]){
swap(&arr[i],&arr[j]);
}
}
}
}
进行交换时,注意忽略掉重复的字符交换:
void Permulation(char *arr,int k,int length){
int i;
if(k == length){
for(i=0;i<length;i++)
printf("%c",arr[i]);
printf("n");
}else{
for(i=k;i<length;i++){
if(k != i && arr[k] == arr[i])
continue;
swap(&arr[k],&arr[i]);
bubbleSort(arr,k+1,length);
Permulation(arr,k+1,length);
bubbleSort(arr,k+1,length);
}
}
}
每次在进行交换后,都把剩余的元素进行一次排列。比如字符串abc,在进行最后一次外层交换时变成 cba。
此时要进行一次排序,交换cab后,在进行排列。
全部代码:
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
void bubbleSort(char *arr,int begin,int length);
void swap(char *a,char *b);
void Permulation(char *arr,int k,int length);
int main(){
char arr[10];
int length;
int i;
while(gets(arr)){
length = strlen(arr);
bubbleSort(arr,0,length);
Permulation(arr,0,length);
}
return 0;
}
void Permulation(char *arr,int k,int length){
int i;
if(k == length){
for(i=0;i<length;i++)
printf("%c",arr[i]);
printf("n");
}else{
for(i=k;i<length;i++){
if(k != i && arr[k] == arr[i])
continue;
swap(&arr[k],&arr[i]);
bubbleSort(arr,k+1,length);
Permulation(arr,k+1,length);
bubbleSort(arr,k+1,length);
}
}
}
void swap(char *a,char *b){
char c;
c = *b;
*b = *a;
*a = c;
}
void bubbleSort(char *arr,int begin,int length){
int i,j;
for(i=begin;i<length;i++){
for(j=i+1;j<length;j++){
if(arr[i]>arr[j]){
swap(&arr[i],&arr[j]);
}
}
}
}
/**************************************************************
Problem: 1369
User: xhalo
Language: C
Result: Accepted
Time:470 ms
Memory:912 kb
****************************************************************/
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法