#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]; /*容纳输出行的数组*/
int i;
/*读取该串列标记*/
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 1;
}
/*读取列标记,如果超出规定范围则不予理睬*/
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;
}
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';
}
C和指针开头的程序
最新推荐文章于 2024-04-19 12:58:58 发布