从标准输入行读取输入行并在标准输出中打印这些输入行

#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 conlumns[]);

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("Original input:%s\n",input);
		rearrange(output,input,n_columns,columns);
		printf("Rearranged line:%s\n",output);
	}
    return EXIT_SUCCESS;
}

//读取列标号、如果超出规定范围则不予理会
int read_column_numbers(int columns[],int max)
{
	int num=0;
	int ch;
	//取得列标号,如果所取得的梳子小于0则停止
	while(num<max && scanf("%d",&columns[num])==1 && columns[num]>=0)
		num+=1;
	//确认已经读取的标号为偶数个,因为他们是以对的形式出现的
	if(num%2!=0)
	{
		puts("Last column number is not paired.");
		exit(EXIT_FAILURE);
	}
	//丢弃该行中包含最后一个数字的那部分内容
	while((ch=getchar())!=EOF && ch!='\n')
		;

	return num;
}

//处理输入行,将指定列的字符连接在一起,输出行一NUL结尾
void rearrange(char *output,char const *input,
			   int n_columns,int const columns[] )
{
	int col;
	int output_col;
	int len;

	len=strlen( input );
	output_col=0;
	//处理每对列标号
	for(col=0;col<n_columns;col+=2)
	{
		int nchars=columns[col+1]-columns[col]+1;
		//如果输入行结束或输出行数组已满,就结束任务
		if(columns[col]>=len || output_col == MAX_INPUT - 1)
			break;
		//如果输出数据空间不够,只复制可以容纳的内容
		if(output_col +nchars > MAX_INPUT-1)
			nchars=MAX_INPUT - output_col -1;
		//复制相关数据
		strncpy(output + output_col,input + columns[col],nchars);
		output_col += nchars;
	}
	output[output_col]='\0 ';
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值