在运行一个C程序是出现了这样的有关问题,为什么,该怎么解决

在运行一个C程序是出现了这样的问题,为什么,该如何解决?
本帖最后由 u012318965 于 2013-10-27 21:24:20 编辑
运行截图:在运行一个C程序是出现了这样的有关问题,为什么,该怎么解决
这是《C和指针》第一章的例题,核对了几次,代码没有发现问题。
源代码:
//输入输出
#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,columns[MAX_COLS];
char input[MAX_INPUT],ouput[MAX_INPUT];

n_columns=read_column_numbers(columns,MAX_COLS);

while(gets_s(input)!=NULL)
{
printf("Original input :%s\n",input);
rearrange(ouput,input,n_columns,columns);
printf("Rearranged line:%s\n",ouput);
}

system("pause");
return EXIT_SUCCESS;
}

int read_column_numbers(int columns[],int max)
{
int num=0;
int ch;

while(num<max && scanf_s("%d",&columns[num])==1 && columns[num]>=0)
num++;

if(num%2!=0)
{
puts("Last column number is not pairde.");
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,output_col,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;
}
}

编译器是VS2012,F5运行的结果就是这个,求问下为什么会产生这个问题,有办法解决么?

------解决方案--------------------
《C和指针》是本值得购买的名著,俺去年才在卓越买了本实体书,关键也便宜在运行一个C程序是出现了这样的有关问题,为什么,该怎么解决。进阶后再看它吧。
另外《c primer》不是《c++ primer》