- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
我正在尝试编写一个程序,该程序从文件中获取输入行并使其恰好为 80 个字符(假设输入行始终小于 80),然后打印该行。这是通过在以下标点符号后添加最多两个空格来完成的:.,!;?如果一行少于 41 个字符,则不加修改地打印。
如果该行仍然不是 80 个字符,则可以在整行中添加随机空格,对此统一性无关紧要。
输入文件是:Lorem Ipsum 只是打印和排版行业的虚拟文本吗?定理自 1500 年代以来,Ipsum 一直是行业的标准虚拟文本,当时不知名的打印机拿了一个活字样,然后把它打乱做成活字样书。它不仅存活了五个世纪,而且还跃入了电子领域排版,基本保持不变。它在1960年代流行随着包含 Lorem Ipsum 段落等的 Letraset 表的发布最近使用桌面出版软件,如 Aldus PageMaker,包括Lorem Ipsum 的版本。
输出文件应如下所示:
这个。注意每一行是如何对齐的
这是我的代码:
const int maxLine = 80;
ifstream fin("unjustified.txt");
ofstream fout("justified.txt");
void randomSpace(string &input);
void spaceAdder(string &input);
int main() {
string inputLine;
while (getline(fin, inputLine)) {
if (inputLine.size() > 40)
{
spaceAdder(inputLine);
}
else {
fout << inputLine << endl;
}
}
system("pause");
fin.close();
fout.close();
return 0;
}
void spaceAdder(string &input) {
int perPos = input.find('.');
while (perPos != string::npos && input.size() < maxLine) {
input.insert(perPos + 1, " ");
perPos = input.find('.', perPos + 1);
}
int commaPos = input.find(',');
while (commaPos != string::npos && input.size() < maxLine) {
input.insert(commaPos + 1, " ");
commaPos = input.find(',', commaPos + 1);
}
int questPos = input.find('?');
while (questPos != string::npos && input.size() < maxLine) {
input.insert(questPos + 1, " ");
questPos = input.find('?', questPos + 1);
}
int semiPos = input.find(';');
while (semiPos != string::npos && input.size() < maxLine) {
input.insert(semiPos + 1, " ");
semiPos = input.find(';', semiPos + 1);
}
int exclamPos = input.find('!');
while (exclamPos != string::npos && input.size() < maxLine) {
input.insert(exclamPos + 1, " ");
exclamPos = input.find('!', exclamPos + 1);
}
if (input.size() < maxLine) {
randomSpace(input);
}
else
fout << input << endl;
}
void randomSpace(string &input) {
srand(time(0));
while (input.size() < maxLine) {
int spacePos = input.find(" ");
bool i = (rand() % 2 == 1) ? true : false;
if (i = true && spacePos != string::npos)
{
input.insert(spacePos, " ");
spacePos = input.find(" ", spacePos + 1);
}
}
fout << input << endl;
}
但是我的代码创建的输出是:
这个。请注意第 2 行和第 4 行如何与文本的其余部分不对齐
我这辈子都弄不明白我的代码有什么问题。请指出正确的方向!谢谢
最佳答案
一个简单的 C++ 代码可以是:
std::ifstream input_file_stream( "file" );
unsigned counter = 0;
while( ++counter <= 80 && std::char_traits< char >::not_eof( input_file_stream.peek() ) ){
std::cout << char ( input_file_stream.get() );
if( counter == 80 ){
std::cout << '\n';
counter = 0;
}
}
每行输出长度为80个字符:
除了使用 std::cout
,您还可以将其写入输出文件
此外,这里还缺少一些单词,例如第 2 行末尾和第 3 行开头的 the
。
因此,另一种解决方案可能是这样的:
Is Lorem Ipsum just dummy text of the printing and typesetting industry? Lorem
Ipsum has been the industry's standard dummy text ever since the 1500s, when
an unknown printer took a galley of type and scrambled it to make a type specimen
book. It has survived not only five centuries, but also the leap into electronic
typesetting, remaining essentially unchanged. It was popularised in the 1960s
with the release of Letraset sheets containing Lorem Ipsum passages, and more
recently with desktop publishing software like Aldus PageMaker including
versions of Lorem Ipsum.
std::ifstream input_file_stream( "file" );
unsigned max_size = 0;
for( std::string line; std::getline( input_file_stream, line ); ){
// find the longest line
if ( max_size < line.size() ) max_size = line.size();
}
input_file_stream.clear();
input_file_stream.seekg( 0 , std::ios_base::beg ); // rewind
for( std::string line; std::getline( input_file_stream, line ); ){
if( line.size() == max_size ){
std::cout << line << '\n';
} else if ( line.size() > 70 ) {
line.insert( line.rfind( ' ' ),std::string( max_size - line.size() ,' ' ) );
std::cout << line << '\n';
} else {
std::cout << line << '\n';
}
}
input_file_stream.close();
Is Lorem Ipsum just dummy text of the printing and typesetting industry? Lorem
Ipsum has been the industry's standard dummy text ever since the 1500s, when
an unknown printer took a galley of type and scrambled it to make a type specimen
book. It has survived not only five centuries, but also the leap into electronic
typesetting, remaining essentially unchanged. It was popularised in the 1960s
with the release of Letraset sheets containing Lorem Ipsum passages, and more
recently with desktop publishing software like Aldus PageMaker including
versions of Lorem Ipsum.
就是这么简单。首先,您需要找到最长的行,这里是 81,然后根据这条最长的行,您可以使用 line.rfind
(意味着最后找到thing) 和 line.insert
来插入你想要的东西。每行的长度由您决定。这里我使用了 81 到 70 之间的值。
每一行都基于这一行对齐:
an unknown printer took a galley of type and scrambled it to make a type specimen
但是这里的输出并不漂亮,因为所有空间都聚集在最后。为此,您可以在 else if
部分的其他空间之间展开 所有空间,如下所示:
} else if ( line.size() > 70 ) {
unsigned need_space = max_size - line.size();
unsigned count_space = std::count( line.begin(), line.end(), ' ' );
std::istringstream iss( line );
std::string temp_line;
while( need_space-- && count_space-- ){
std::string temp;
iss >> temp;
temp_line += temp + "__";
}
iss.get(); // get rid of a single space in the iss stream
// extracts the rest of the iss stream:
temp_line.append( std::istreambuf_iterator<char>( iss ), std::istreambuf_iterator<char>() );
std::cout << temp_line << '\n';
} else {
std::cout << line << '\n';
}
输出:
Is__Lorem__Ipsum__just dummy text of the printing and typesetting industry? Lorem
Ipsum__has__been__the__industry's__standard dummy text ever since the 1500s, when
an unknown printer took a galley of type and scrambled it to make a type specimen
book.__It has survived not only five centuries, but also the leap into electronic
typesetting,__remaining__essentially__unchanged.__It was popularised in the 1960s
with__the__release__of__Letraset sheets containing Lorem Ipsum passages, and more
recently__with__desktop__publishing__software__like__Aldus__PageMaker__including
versions of Lorem Ipsum.
正如您在这里看到的,我使用 __
而不是 2-spaces
来显示输出中发生的情况,因此您可以将其更改为 2 个空格。虽然代码仍然有一些问题,例如 the line before last 没有像其他的那样固定,但我不想让代码变得复杂,我认为这对大多数情况来说已经足够了。
关于c++ - 基本 C++ 文本对齐,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42894749/
我希望能够像在 jsFiddle 中那样将元素列表对齐到右侧的复选框。这是如何做到这一点的最佳实践?传统上我从来没有 float 过相互嵌套的元素,所以我想确定这是否是解决此问题的正确方法。 代码(h
指令.align n是什么意思在数组中做什么? 更具体地说,假设我有以下部分代码: array: .align 2 .space 800 它的重要性是什么,为什么不跳过它并使用
基本上我正在寻找一种强制特定相对对齐的方法 即我想保证其他一些值(value) m s.t m > n alignment_of(foo) % 2^m == 2^n IE: .align 2^m; .
在我的代码中,我必须考虑一个数组数组,其中内部数组具有固定维度。为了使用 STL 算法,将数据实际存储为数组的数组很有用,但我还需要将该数据传递给 C 库,该库采用扁平化的 C 样式数组。 如果能够以
横向上,我想显示两个位图,并在它们之间显示一个标签字段。 代码看起来很简单,但所有字段都添加在屏幕左侧。 HorizontalFieldManager hfm = new HorizontalFiel
我想绘制一个变量名称及其符号。因为某些变量的名称很长,所以我试图将换行符与轴标签混合使用。这会导致对齐中发生有趣的事情: par(mar=c(1,12,1,1)) plot( y=1:6, 1:6,
使用这个脚本 df <- data.frame(x = 1:5, y = 1:5, color = letters[1:5]) ggplot(df, aes(x, y, fill = color))
我有一个带有标量字段的结构,比如妈妈,我想在屏幕上对齐的列中显示结构的值,可能还有一些标题。这是一个最小的工作示例: mom.a = 1; mom.b = 2; mom.veryLongName =
在 iOS6 中,我使用自动布局。 我有 2 个以编程方式创建的 View v1 和 v2。 v2 作为 subview 添加到 v1 v1 的约束已通过编程方式创建(此处未显示)。 我希望 v1 和
概述 浏览时operator new, operator new[] - cppreference.com ,似乎我们有许多选项来分配具有特定对齐要求的对象数组。但是,没有指定如何使用它们,而且我似乎
Widget _createProfileContainer() { return new Container( height: 64.0, child: ne
我正在使用 Bootstrap 和语义 UI 的组合来设计和对齐我的网页。目前,我在将页面 api map 和博客文章在整个页面上对齐时遇到问题,而不是像图像所示 那样堆叠在一起。 这是我的底层代码,
所以我已经添加了标签和所有内容,但我仍然在格式化和对齐所有内容时遇到问题。计算按钮显然应该居中。我知道使用 gridbag 将框架分割成坐标系,当一列大于其他列时,它会调整其他列并将其抛弃(对吗?)。
我必须将程序上的按钮对齐到中间,我运行的当前代码但显示的按钮与程序一样大,我想要一个特定大小的中心按钮,这是我尝试过的 /** * Created by Timk9 on 11/04/2016.
我正在尝试将 VIM 作为我的 ruby/rails 编辑器。太胖了,我对它的功能印象深刻 并且我能够安装以下插件以提供更好的 IDE 体验 自动配对 Better-snipmate-snippe
在结构内对齐成员的最佳或常规方法是什么?添加虚拟数组是最佳解决方案吗? 我有一个 double 的结构和 double 的三倍是吗? struct particle{ double mass;
我正在尝试对齐我的输出,但由于某种原因我无法做到我多么想要它,这真的很令人沮丧。标题不会正确对齐。我不知道我是否正确使用了 setw()。 #include using std::cout; usi
我正在开发一个 android 应用程序,其相对布局如下所示。 这是应用程序在屏幕上的显示方式的 imgur 链接:http://imgur.com/c4rNJ .我希望“Text 1”出现在“a l
我不确定为什么我不能在下面的代码中调整按钮的位置。我有几行设置了边界,但我一定遗漏了一些东西。 public DayGUI() { mainFrame = new JF
我有一个 html 页面,我想在页面底部对齐一个 iframe,使 iframe 占据所有宽度,我无法在底部对齐 iframe。请找到底部的 iframe 标签页面。 The rest of th
我是一名优秀的程序员,十分优秀!