• 2.4.2程序作业


    本程序能正确统计某程序设计语言源文件的字符数,单词数和行数,并能实现部分拓展功能,如返回程序的代码行/空行/注释行/。程序攻分为4个主要函数,分别统计行数程序,统计字符数和单词数函数,返回代码行和空行函数,返回注释行函数。但程序不完善,我没有写出能递归处理目录下符合条件的文件函数。高级功能我也没有实现。能力有限,只能期待日后改进。

    #include<stdio.h>
    #include<stdlib.h>
    #include<string.h>
    
    
    
     void hangshu()
    {    
      int num=0;
      FILE*fp;
      char str[500];
    
      if((fp=fopen("test.txt","rt"))==NULL) 
      {
       printf("cannot open file
    ");
       return;
      }
           
        while (fgets(str,500,fp))  
        {
          num++;
       }
      fclose(fp);
       printf("该文件共有%d行
    ",num);
    }
    
    
    void count()
    {
        char str[500];
    	int strLen;
         FILE*fp;
        
    	int i;
    	int j;
    	int blank=0;
    	int ch=0;
    	int word=0;
     
    
      if((fp=fopen("test.txt","rt"))==NULL) 
      {
       printf("cannot open file
    ");
       return;
      }
    
      
     while(fgets(str, 500, fp))
     {
            strLen = strlen(str);
    		for(i=0;i<strLen;i++)
    		{
    			j=str[i];
    			if(j==' '||j=='	')
    			{
    		!blank&&word++;
    		blank=1;
    			
    			}
    			else if(j!='
    '&&j!='
    ')
    			{
    				ch++;
    			blank=0;
    			
    			}
    		}
            !blank&&word++;
    		blank=1;
    		
     }
       printf("共有%d个单词,%d个字符",word,ch);
    }
    
     void advanced()
     {
    
    int strLen;	 
    
    	
     FILE*fp;
     char str[500];
    
    
      if((fp=fopen("test.txt","rt"))==NULL) 
      {
       printf("cannot open file
    ");
       return;
      }
    
           
        while (fgets(str,500,fp))  
    	{
    		
            strLen = strlen(str);
    	
             if(strLen>3)
    		 {
    			printf("%s是代码行.
    ",str);
    		 }
    		 
    
    		 if(strLen<=3)
    		  {
             
                printf("%s是空行.
    ",str);
    		  }	
    	}
    		
     }   
    
    
    
    void zhushi()
    {
             FILE*fp;
             int i =0;
            
             char str[500];
            if((fp=fopen("test.txt","rt"))==NULL) 
      {
       printf("cannot open file
    ");
       return;
      }
           
    		fp=fopen("test.txt","r");
        while(fgets(str,500,fp))
        {
                str[i]=fgetc(fp);
                    i++;
            }
            if (str[i]='\')
    			printf("%s是注释行
    ",str);
        fclose(fp);
              
    }
    
    
    	
    void Menu()
    {
            printf("--------------------
    ");
        printf("----程序主菜单------
    "); 
        printf("--------------------
    ");
        printf("----1显示行数---
    ");
     printf("----2显示单词数和字符数----
    ");
     printf("----3返回代码行和空行-------
    ");
     printf("----4返回注释行-------
    ");
    
            printf("----5退出-----------
    ");
        printf("---回车键返回菜单---
    "); 
        printf("--------------------
    ");
            printf("---请选择:(1-5)-:---
    ");
    
    }
    
    
    void main()
    {
            char menuNum;
           
            while(1)
            {
                    Menu();
                    scanf("%d",&menuNum);
            switch(menuNum)
            {
                   
    
                 case 1:
    				    hangshu();
                        break;
    			 case 2:
                        count();
    					break;
    			 case 3:
    				    advanced();
    				    break;
    			 case 4:
    				   zhushi();
    				   break;
            case 5:
                          
                            exit(0);
            
            default:
                            printf("
    输入错误!
    ");
                    printf("按任意键返回....
    ");
                   getchar();
    
    }
    }
    }
    

      

  • 相关阅读:
    v-chart使用的相关实例
    v-chart从后台获取数据
    算法题-单词搜索
    关于前端开发的一些小经验总结
    element的input中加入可点击的按钮
    vue.js的入门
    链表问题(算法题)
    同构词分类
    最长不降序子列的改编(dp数组的使用)
    Ubuntu安装Git
  • 原文地址:https://www.cnblogs.com/ysw6/p/5310962.html
Copyright © 2020-2023  润新知