第7周 C语言程序设计(新2版) 例题1.9 字符数组(打印最长输入行)

本文探讨了如何使用C语言编程找出并打印最长的输入行。内容包括两个部分:一是简单介绍如何打印最长输入行的问题,二是展示解决任意长度输入行长度的代码实现。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1、打印最长输入行

问题及代码:

/*打印最长输入行*/
#include <stdio.h>
#define MAXLINE 100
int getline(char line[],int maxline); 
void copy(char to[],char from[]);
int main()
{
	int len;  //当前行长度 
	int max;  //目前为止发现的最行的长度 
	char line[MAXLINE];  //当前的输入行 
	char longest[MAXLINE];   //用于保存最长的行 
	
	max=0;
	while((len=getline(line,MAXLINE))>0) 
	if(len>max)
	{
	max=len;
	copy(longest,line);
    }
    if(max>0)   //存在这样的行 
     	printf("%s",longest);
	return 0;
 } 
 /*输入一行,并返回其长度*/
 int getline(char s[],int lim)
 {
 	int c,i;
 	for(i=0;i<lim-1&&(c=getchar())!=EOF&&c!='\n';i++)
 	    s[i]=c;
 	if(c=='\n')
 	   {
 	    s[i]=c;
 	     i++;
    	 }
    s[i]='\0';  //字符串末尾以'\0'为结尾不能漏了 
 	return i;
 }
 void copy(char to[],char from[]) 
 {
 	int i;
 	i=0;
 	while((to[i]=from[i])!='\0') //只要复制不到字符的结尾符号‘\n’,循环将持续
	   i++;
 }


2、打印任意长度的输入行长度,并尽可能打印文本

问题及代码:

#include <stdio.h>  
#define MAXLINE 1000 
int getline(char line[],int maxline);   
void copy(char to[],char from[]);  
int main()  
{  
    int len;  //当前行长度   
    int max;  //目前为止发现的最行的长度   
    char line[MAXLINE];  //当前的输入行   
    char longest[MAXLINE];   //用于保存最长的行   
      
    max=0;  
    while((len=getline(line,MAXLINE))>0)   
    { 
      printf("%d %s",len,line);  //尽可能多的打印输入行的长度与保存的数组 
    if(len>max)  
       {  
    max=len;  
    copy(longest,line);  
       }  
    } 
    if(max>0)   //存在这样的行   
        printf("%s",longest);  
    return 0;  
 }   
 /*输入一行,并返回其长度*/  
 int getline(char s[],int lim)  
 {  
    int c,i,j;  
    j=0;    //j记录复制到字符串s中字符的个数 
    for(i=0;(c=getchar())!=EOF&&c!='\n';i++)  //不再检查字符数是否超出数组s的限制 
        if(i<lim-2)   //数组s的最后一个下标是lim-1; 
        {
        	s[j]=c;
        	j++;
		} 
    if(c=='\n')  
       {  
        s[j]=c;
		 j++;  
         i++;  
         }  
    s[j]='\0';  //字符串末尾以'\0'为结尾不能漏了   
    return i;  
 }  
 void copy(char to[],char from[])   
 {  
    int i;  
    i=0;  
    while((to[i]=from[i])!='\0') //只要复制不到字符的结尾符号‘\n’,循环将持续  
       i++;  
 }  

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值