[C和指针] rearrange.c
C和指针_程序1.1_重排字符
/*
** 这个程序从标准输入(键盘)中读取输入行并按需求处理后在标准输出(屏幕)中打印,
** 每个输入行的后面一行是该行按需求处理后的输出内容。
**
** 输入的第1行是一串列标号,串的最后以一个负数结尾。
** 这些列标号成对出现,说明需要打印的输入行的列的范围。
** 例如,0 3 10 12 -1 表示第0列到第3列,第10列到第12列的内容将被打印。
*/ #include <stdio.h>
#include <stdlib.h>
#include <string.h>
#define MAX_COLS 20 /* 所能处理的最多列标号数量 */
#define MAX_INPUT 1000 /* 所能处理的最大输入行长度 */ int read_column_numbers(int columns[], int max);
void rearrange(char *output, char const *input, int n_columns, int const columns[]); int main(void)
{
int n_columns; /* 记录君:实际读取的列标号个数 */
int columns[MAX_COLS]; /* 容器君:实际读取的列标号们 */
char input[MAX_INPUT]; /* 容器君:输入行字符串 */
char output[MAX_INPUT]; /* 容器君:输出行字符串 */ /*
** 读取该串列标号并统计个数
*/
n_columns = read_column_numbers(columns, MAX_COLS); /*
** 读取、处理和打印剩余的输入行
*/
while(gets(input) != NULL)
{
printf("原始输入: %s\n", input);
rearrange(output, input, n_columns, columns);
printf("截取输出: %s\n", output);
} return EXIT_SUCCESS;
} /*
** 读取列标号(存入数组),超出规定范围(2)则不予理会
**
** 参数表: columns 列标号存储用数组
** max 数组最大容量
**
** 返回值: num 实际读取的列标号个数
*/
int read_column_numbers(int columns[], int max)
{
int num = ; /* 计数君:当前已读入列标号的数量 */
int end_ch; /* 记录君:结束字符 */ /*
** 读入列标号,如果所读取的数小于0则停止
*/
while(num < max && scanf("%d", &columns[num]) == && columns[num] >= )
{
num += ;
} /*
** 确认已经读取的标号为偶数个,因为它们是以对儿的形式出现的
*/
if(num % != )
{
puts("Last column number is not paired.");
exit(EXIT_FAILURE);
} /*
** 丢弃超出的列标号,防止被解释为第1行数据
*/
while( (end_ch = getchar()) != EOF && end_ch != '\n' )
; return num;
} /*
** 处理输入行,将指定列的字符连接在一起,输出行以NUL结尾
*/
void rearrange(char *output, char const *input, int n_columns, int const columns[])
{
int i; /* 计数君:columns 数组的下标 */
int len; /* 记录君:输入行的长度 */
int out_emp_i; /* 计数君:输出数组可用空间首位置下标 */ len = strlen(input); out_emp_i = ; /* bug:忘记初始化 */ /*
** 处理每对列标号
*/
for(i = ; i < n_columns; i += )
{
int nchars = columns[i+] - columns[i] + ; /* 本次写入输出的字符数 */ /*
** 如果输入行结束或输出行数组已满,则结束任务
*/
if(columns[i] >= len || out_emp_i == MAX_INPUT - )
{
break;
} /*
** 如果输出行数据空间不够,只复制可以容纳的数据
*/
if(out_emp_i + nchars > MAX_INPUT - )
{
nchars = MAX_INPUT - - out_emp_i;
} /*
** 复制相关的数据 (赞指针偏移的用法)
*/
strncpy(output + out_emp_i, input + columns[i], nchars);
out_emp_i += nchars;
}
output[out_emp_i] = '\0';
}
[C和指针] rearrange.c的更多相关文章
- 《C与指针》第一章练习
本章例程 程序1.1 重排字符 #include <stdio.h> #include <stdlib.h> #include <string.h> #define ...
- 《c和指针》1.5编程练习问题
<c和指针>1.5编程练习问题 #include<stdio.h>#include<stdlib.h>#include<string.h>#define ...
- C语言学习书籍推荐《C和指针 Pointers On C》下载
<C和指针 POINTERS ON C>提供与C语言编程相关的全面资源和深入讨论.本书通过对指针的基础知识和高 级特性的探讨,帮助程序员把指针的强大功能融入到自己的程序中去. 全书共18 ...
- TODO:Golang指针使用注意事项
TODO:Golang指针使用注意事项 先来看简单的例子1: 输出: 1 1 例子2: 输出: 1 3 例子1是使用值传递,Add方法不会做任何改变:例子2是使用指针传递,会改变地址,从而改变地址. ...
- enote笔记法使用范例(2)——指针(1)智能指针
要知道什么是智能指针,首先了解什么称为 “资源分配即初始化” what RAII:RAII—Resource Acquisition Is Initialization,即“资源分配即初始化” 在&l ...
- C++虚函数和函数指针一起使用
C++虚函数和函数指针一起使用,写起来有点麻烦. 下面贴出一份示例代码,可作参考.(需要支持C++11编译) #include <stdio.h> #include <list> ...
- C++11 shared_ptr 智能指针 的使用,避免内存泄露
多线程程序经常会遇到在某个线程A创建了一个对象,这个对象需要在线程B使用, 在没有shared_ptr时,因为线程A,B结束时间不确定,即在A或B线程先释放这个对象都有可能造成另一个线程崩溃, 所以为 ...
- c 数组与指针的使用注意事项
数组变量和指针变量有一点小小的区别 所以把数组指针赋值给指针变量的时候千万要小心 加入把数组赋值给指针变量,指针变量只会包含数组的地址信息 而对数组的长度一无所知 相当于指针丢失了一部分信息,我们把这 ...
- Marshal.Copy将指针拷贝给数组
lpStatuss是一个UNITSTATUS*的指针类型实例,并包含SensorDust字段 //定义一个数组类型 byte[] SensorDust = new byte[30] //将指针类型拷贝 ...
随机推荐
- 如何获取SQL Server数据库元数据的方法
发布时间:2007.06.15 05:05 来源:赛迪网 作者:3946469 元数据简介 元数据 (metadata) 最常见的定义为“有关数据的结构数据”,或者再简单一点就是“关于数据 ...
- Redis & Sentinel 安装脚本
#!/bin/bash # 判断是否为root用户,不是root用户提示退出 if [[ $EUID -ne 0 ]]; then echo "This script. must be ...
- [转载]传智播客_SQL入门
原文地址:传智播客_SQL入门作者:happylonger SQL * 数据定义语言 DDL * 数据操作语言 DML * 查询和更新指令构成了 SQL 的 DML 部分: * SELECT - 从 ...
- Python 基础【第七篇】集合
一.集合的概念: 不同元素的集合 二.集合的方法: 方法 用法 范例 set() 过滤掉重复 设置成为集合 >>> subset=set([1,1,2,3,4,4,6]) >& ...
- VSPackge插件系列:如何正确获取DTE
做VS插件开发,不得不了解DTE,有了DTE我们就可以与VS交互了,比如说获取当前选择的文件,比如说获取当前主窗口,比如说获取编译器等等,关于DTE接口更多的说明我把接口地址贴出来方便大家查阅. ht ...
- RGBa颜色 css3的Alpha通道支持
CSS3中,RGBa 为颜色声明添加Alpha通道. RGB值被指定使用3个8位无符号整数(0 – 255)并分别代表红色.蓝色.和绿色.增加的一个alpha通道并不是一个颜色通道——它只是用来指定除 ...
- lex/flex 笔记
Lex的匹配策略: 1. 按最长匹配原则确定被选中的单词 2. 如果一个字符串能被若干正规式匹配,则先匹配排在前面的正规式. lex源程序的写法:Lex源程序必须按照Lex语言的规范来写,其核心是一组 ...
- nyoj 96 n-1位数(处理前导 0 的情况)
n-1位数 时间限制:3000 ms | 内存限制:65535 KB 难度:1 描述 已知w是一个大于10但不大于1000000的无符号整数,若w是n(n≥2)位的整数,则 ...
- 蓝牙 GameKit
一.准备工作 1.搭建UI 2.拖线 // 图片 @property (weak, nonatomic) IBOutlet UIImageView *imageView; // 建立连接 - (IB ...
- WindowManage与Window的在Activity的一点小应用
super.onCreate(savedInstanceState); getWindow().setFlags(WindowManager.LayoutParams.FLAG_KEEP_SCREEN ...