UVa Problem 848 Fmt (Fmt 程序)

本文介绍了一个文本格式化处理程序的设计与实现,通过使用缓冲区概念来处理输入文本,确保每行不超过指定宽度,并且能够正确处理空格和换行。
// Fmt (Fmt 程序) // PC/UVa IDs: 110308/848, Popularity: C, Success rate: low Level: 2 // Verdict: Accepted // Submission Date: 2011-05-22 // UVa Run Time: 0.008s // // 版权所有(C)2011,邱秋。metaphysis # yeah dot net // // 直接根据题意即可,有些繁琐。利用缓冲区的概念进行处理会相对的显得程序逻辑清晰一些。 #include <iostream> using namespace std; #define WIDTH 72 // 一行最大宽度 string buffer; // 缓冲区。 // 判断某行是否是空行。 bool empty_line(string & line) { return line.length() == 0; } // 判断该行是否是新行。 bool new_line(string & line) { if (empty_line(line)) return false; return line[0] == ' '; } // 移除行末尾的空格。 void trim_line(string & line) { for (string::iterator it = line.end() - 1; it >= line.begin(); it--) if (*it == ' ') line.erase(it); else break; } // 处理缓冲区的内容。 void process_buffer() { // 当缓存区有内容时输出。 if (buffer.length() > 0) { if (buffer.length() <= WIDTH) { cout << buffer << endl; buffer.clear(); return; } string line, word; string::iterator it = buffer.begin(); string spaces; // 首先读入该行的前导空格。 for (; it != buffer.end() && *it == ' '; spaces.append(1, ' '), it++) ; // 将前导空格附加到输出行。 line.append(spaces); spaces.clear(); // 读取非空格字符直到遇到空格。 for (; it != buffer.end() && *it != ' '; line.append(1, *it), it++) ; // 判断是否需要输出该行。 if (line.length() >= WIDTH) { cout << line << endl; line.clear(); } // 输出行字符数小于或等于宽度 WIDTH,继续读取字符,直到缓冲区结束。 while (line.length() <= WIDTH && it != buffer.end()) { // 判断是否需要读入一个新的单词。 if (word.length() == 0) { // 读入前导空格。 for (; it != buffer.end() && *it == ' '; spaces.append(1, ' '), it++) ; // 读入单词。 for (; it != buffer.end() && *it != ' '; word.append(1, *it), it++) ; } // 判断单词长度是否大于 WIDTH,决定是否占一行输出。 if (word.length() >= WIDTH) { cout << line << endl << word << endl; line.clear(); word.clear(); spaces.clear(); } else { // 若当前输出行为空,则需将前导空格去掉。 if (line.length() == 0) spaces.clear(); // 判断当前行加上空格和单词的长度是否超过指定长度,若超过则直接输出当前行 // 空格清空,单词留到下一行。若未超过则将其合成一行内容。由于两个单词之间可能 // 是多个空格,所以采用了单独读取空格的方式。 if ((line.length() + spaces.length() + word.length()) <= WIDTH) { line.append(spaces).append(word); word.clear(); spaces.clear(); } else { cout << line << endl; line.clear(); spaces.clear(); } } } // 判断是否有内容仍需要输出。 if (line.length() > 0) cout << line << endl; if (word.length() > 0) cout << word << endl; buffer.clear(); } } int main(int ac, char *av[]) { string line; while (getline(cin, line)) { // 截去行末尾的空格。 trim_line(line); // 截去行末尾的空格后,空行和只有空格的空白行将都变成空行,有利于判断。 // 若遇到空行或新行,表示要将前面缓冲区的内容处理输出。 if (empty_line(line) || new_line(line)) { process_buffer(); // 换行。 if (empty_line(line)) cout << endl; else buffer.append(line); } else { // 若缓冲区内容为空,直接将新的一行附加到缓冲区,否则需要在缓冲区和 // 新一行内容间附加一个空格。 if (buffer.length() == 0) buffer.append(line); else buffer.append(1, ' ').append(line); } } // 处理缓冲区内剩余的内容。 process_buffer(); return 0; }

六自由度机械臂ANN人工神经网络设计:正向逆向运动学求解、正向动力学控制、拉格朗日-欧拉法推导逆向动力学方程(Matlab代码实现)内容概要:本文档围绕六自由度机械臂的ANN人工神经网络设计展开,详细介绍了正向与逆向运动学求解、正向动力学控制以及基于拉格朗日-欧拉法推导逆向动力学方程的理论与Matlab代码实现过程。文档还涵盖了PINN物理信息神经网络在微分方程求解、主动噪声控制、天线分析、电动汽车调度、储能优化等多个工程与科研领域的应用案例,并提供了丰富的Matlab/Simulink仿真资源和技术支持方向,体现了其在多学科交叉仿真与优化中的综合性价值。; 适合人群:具备一定Matlab编程基础,从事机器人控制、自动化、智能制造、电力系统或相关工程领域研究的科研人员、研究生及工程师。; 使用场景及目标:①掌握六自由度机械臂的运动学与动力学建模方法;②学习人工神经网络在复杂非线性系统控制中的应用;③借助Matlab实现动力学方程推导与仿真验证;④拓展至路径规划、优化调度、信号处理等相关课题的研究与复现。; 阅读建议:建议按目录顺序系统学习,重点关注机械臂建模与神经网络控制部分的代码实现,结合提供的网盘资源进行实践操作,并参考文中列举的优化算法与仿真方法拓展自身研究思路。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值