从文件读取字符串,并求出该字符串包含的字符集中所有字符的全部组合

本文主要是介绍从文件读取字符串,并求出该字符串包含的字符集中所有字符的全部组合,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

求给定字符集中所有字符的全部组合。首先从文件“data.txt”中读取字符集,并识别出字符集中的每一个字符。假设字符集的总字符数为n,利用这个n个字符组成长为n的字符串。其中每个字符均可重复使用,每个字符串中也不必包含全部字符。试求出所有长为n的字符串集合。最后将所求的的集合写入文件“result.txt”中。

程序输入输出样例

– data.txt中的内容为

@#

– result.txt中的内容为

@@

@#

#@

##


枚举 递归     卡了半天,纯粹的弱智不解释。。。。。


//
//  main.cpp
//  str
//
//  Created by Bryan on 14-6-28.
//  Copyright (c) 2014年 Bryan. All rights reserved.
//#include <iostream>
#include <string>
#include <vector>
#include <algorithm>
#include <fstream>
#include <list>using namespace std;list<char> GetCharsFromFile()
{ifstream inFile("data.txt");list<char> ret;if(inFile){string s;getline(inFile,s);for(int i = 0;i<s.length();i++){ret.push_back(s[i]);}ret.sort();ret.unique();inFile.close();return ret;}return ret;
}void CharCombination(vector<string> &strVec,list<char> &charList,char *s,int step)
{if(step == charList.size()){s[step] = '\0';string stmp(s);strVec.push_back(stmp);return;}for(list<char>::iterator it = charList.begin();it != charList.end();it++){s[step] = *it;CharCombination(strVec,charList ,s, step + 1);}}int main(int argc, const char * argv[])
{list<char> charList;charList = GetCharsFromFile();vector<string> ret;char *cstr = new char[charList.size() + 1];CharCombination(ret,charList, cstr,0);ofstream outFile;outFile.open("result.txt");for(int i = 0;i<ret.size();i++)outFile<<ret[i]<<endl;outFile.close();return 0;
}


#include <iostream>
#include <fstream>
#include <vector>
#include <algorithm>using namespace std;void func(vector<char> & s,char *ret,int k,int N,ofstream &outFile)
{if(k == N ){ret[N] = '\0';cout<<ret<<endl;outFile<<ret<<endl;return;}for(int i = 0;i<N;i++){ret[k] = s[i];func(s,ret,k+1,N,outFile);}
}
int main()
{ifstream inFileStream;inFileStream.open("data.txt");ofstream outFileStream;outFileStream.open("result.txt");char *str = new char[1000];inFileStream.getline(str,1000);vector<char> vec;for(int i = 0;i<1000;i++){if(str[i] != '\0')vec.push_back(str[i]);elsebreak;}int N = vec.size();char * ret = new char[N+1];func(vec,ret,0,N,outFileStream);inFileStream.close();outFileStream.close();getchar();}



#include <iostream>
#include <fstream>
#include <string>
#include <vector>using namespace std;void func(const vector<char> &charVec,char* finalStr,ofstream & outFile,int k,int N)
{if(k==N){finalStr[N]= '\0';cout<<finalStr<<endl;outFile<<finalStr<<endl;return;}for(int i= 0;i<N;i++){finalStr[k] = charVec[i];func(charVec,finalStr,outFile,k+1,N);}
}int main()
{ofstream outFile;outFile.open("result.txt");ifstream inFile;inFile.open("data.txt");string inStr;vector<char> charVec;outFile<<"The chars are: ";cout<<"The chars are: ";while(getline(inFile,inStr)){for(string::iterator it = inStr.begin();it != inStr.end();it++){cout<<(*it)<<" ";outFile<<(*it)<<" ";charVec.push_back(*it);}}cout<<endl;int N = charVec.size();char* outStr =new char[N+1];func(charVec,outStr,outFile,0,N);outFile.close();inFile.close();getchar();
}


这篇关于从文件读取字符串,并求出该字符串包含的字符集中所有字符的全部组合的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/570508

相关文章

Python如何实现读取csv文件时忽略文件的编码格式

《Python如何实现读取csv文件时忽略文件的编码格式》我们再日常读取csv文件的时候经常会发现csv文件的格式有多种,所以这篇文章为大家介绍了Python如何实现读取csv文件时忽略文件的编码格式... 目录1、背景介绍2、库的安装3、核心代码4、完整代码1、背景介绍我们再日常读取csv文件的时候经常

Java对象和JSON字符串之间的转换方法(全网最清晰)

《Java对象和JSON字符串之间的转换方法(全网最清晰)》:本文主要介绍如何在Java中使用Jackson库将对象转换为JSON字符串,并提供了一个简单的工具类示例,该工具类支持基本的转换功能,... 目录前言1. 引入 Jackson 依赖2. 创建 jsON 工具类3. 使用示例转换 Java 对象为

C# string转unicode字符的实现

《C#string转unicode字符的实现》本文主要介绍了C#string转unicode字符的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随... 目录1. 获取字符串中每个字符的 Unicode 值示例代码:输出:2. 将 Unicode 值格式化

golang字符串匹配算法解读

《golang字符串匹配算法解读》文章介绍了字符串匹配算法的原理,特别是Knuth-Morris-Pratt(KMP)算法,该算法通过构建模式串的前缀表来减少匹配时的不必要的字符比较,从而提高效率,在... 目录简介KMP实现代码总结简介字符串匹配算法主要用于在一个较长的文本串中查找一个较短的字符串(称为

Java中String字符串使用避坑指南

《Java中String字符串使用避坑指南》Java中的String字符串是我们日常编程中用得最多的类之一,看似简单的String使用,却隐藏着不少“坑”,如果不注意,可能会导致性能问题、意外的错误容... 目录8个避坑点如下:1. 字符串的不可变性:每次修改都创建新对象2. 使用 == 比较字符串,陷阱满

IDEA编译报错“java: 常量字符串过长”的原因及解决方法

《IDEA编译报错“java:常量字符串过长”的原因及解决方法》今天在开发过程中,由于尝试将一个文件的Base64字符串设置为常量,结果导致IDEA编译的时候出现了如下报错java:常量字符串过长,... 目录一、问题描述二、问题原因2.1 理论角度2.2 源码角度三、解决方案解决方案①:StringBui

C#中读取XML文件的四种常用方法

《C#中读取XML文件的四种常用方法》Xml是Internet环境中跨平台的,依赖于内容的技术,是当前处理结构化文档信息的有力工具,下面我们就来看看C#中读取XML文件的方法都有哪些吧... 目录XML简介格式C#读取XML文件方法使用XmlDocument使用XmlTextReader/XmlTextWr

使用Navicat工具比对两个数据库所有表结构的差异案例详解

《使用Navicat工具比对两个数据库所有表结构的差异案例详解》:本文主要介绍如何使用Navicat工具对比两个数据库test_old和test_new,并生成相应的DDLSQL语句,以便将te... 目录概要案例一、如图两个数据库test_old和test_new进行比较:二、开始比较总结概要公司存在多

C#从XmlDocument提取完整字符串的方法

《C#从XmlDocument提取完整字符串的方法》文章介绍了两种生成格式化XML字符串的方法,方法一使用`XmlDocument`的`OuterXml`属性,但输出的XML字符串不带格式,可读性差,... 方法1:通过XMLDocument的OuterXml属性,见XmlDocument类该方法获得的xm

Java实现Elasticsearch查询当前索引全部数据的完整代码

《Java实现Elasticsearch查询当前索引全部数据的完整代码》:本文主要介绍如何在Java中实现查询Elasticsearch索引中指定条件下的全部数据,通过设置滚动查询参数(scrol... 目录需求背景通常情况Java 实现查询 Elasticsearch 全部数据写在最后需求背景通常情况下