• 第五周作业


    这个作业属于那个课程 C语言程序设计II
    这个作业要求在哪里 https://edu.cnblogs.com/campus/zswxy/software-engineering-class1-2018/homework/2825
    我在这个课程的目标是 能够准确的写出代码
    这个作业在那个具体方面帮助我实现目标 一维数组和二维数组
    参考文献 C语言课本和百度

    本题目要求编写程序统计一行字符中单词的个数。所谓“单词”是指连续不含空格的字符串,各单词之间用空格分隔,空格数可以是多个。

    输入格式:
    输入给出一行字符。

    输出格式:
    在一行中输出单词个数。

    输入样例:

    Let's go to room 209.
    

    输出样例:

    5
    

    1、实验代码:

    #include <stdio.h>
    int main()
    {
    	char a;
    	int b=0,count=0;
     
      	while(1){
      		scanf("%c",&a);
    		if(a=='
    '){    
    			break;
    		}else if(a!=' '){ 
    			if(a>='a'&&a<='z'||a>='A'&&a<='Z'||a>='0'&&a<='9')	{
    				count++;   
    				b++;   
    			}
    				while(1){
    					scanf("%c",&a);
    					if(a==' '||a=='
    '){ 
    						break;
    					}
    					b++;
    				}
    			if(b>1){
    				if(a>='a'&&a<='z'||a>='A'&&a<='Z'||a>='0'&&a<='9')	count++; 
    			}
    			if(a=='
    '){
    				break; 
    			}
    		} 
    	}
     
      	printf("%d",count);
        return 0;
    }
    

    2、流程图:

    3、调试过程遇到问题:

    问题1:开始的时候因为不知道到底要输入多少个字符,所以不好用for循环。
    解决办法:翻书查找了一下while循环不需要知道n是多少。

    4、运行结果截图:

    7-1 英文单词排序 (25 分)

    本题要求编写程序,输入若干英文单词,对这些单词按长度从小到大排序后输出。如果长度相同,按照输入的顺序不变。

    输入格式:
    输入为若干英文单词,每行一个,以#作为输入结束标志。其中英文单词总数不超过20个,英文单词为长度小于10的仅由小写英文字母组成的字符串。

    输出格式:
    输出为排序后的结果,每个单词后面都额外输出一个空格。

    输入样例:

    blue
    red
    yellow
    green
    purple
    #
    

    输出样例:

    red blue green yellow purple 
    

    1、实验代码:

    #include <stdio.h>
    #include <string.h>
    int main(void)
    {
        char str[20][10],han[20],lie[10];
        int i,j,n=0;
        while(1)
    	{
        	scanf("%s",lie);
        	if(lie[0]=='#')
    	    {
        		break;
        	}
            else
    		{
            strcpy(str[n],lie);
            n++;
            }
        }
        for(i=0;i<n-1;i++)
        	for(j=0;j<n-i-1;j++)
    	    {
                if(strlen(str[j])>strlen(str[j+1]))
    		    {
                   strcpy(han,str[j]);
                   strcpy(str[j],str[j+1]);
                   strcpy(str[j+1],han);
                }
            }
        for(i=0;i<n;i++)
    	{
            printf("%s ",str[i]);
        }
     return 0;
    }
    

    2、博客园要求代码:

    #include <stdio.h>
    #include <string.h>
    #include<stdlib.h>
    int main(void)
    {
        char str[20][10],han[20],lie[10];
        FILE*fp;
        if((fp=fopen("C:\xuhaitao\RTF.txt","w+"))==NULL)
        {
            printf("File open error!
    ");
            exit(0);
        }
        
        int i,j,n=0;
        while(1)
    	{
    		scanf("%c",lie);
        	fscanf(fp,"%s",lie);
        	if(lie[0]=='1')
    	    {
        		break;
        	}
            else
    		{
            strcpy(str[n],lie);
            n++;
            }
        }
        for(i=0;i<n-1;i++)
        	for(j=0;j<n-i-1;j++)
    	    {
                if(strlen(str[j])>strlen(str[j+1]))
    		    {
                   strcpy(han,str[j]);
                   strcpy(str[j],str[j+1]);
                   strcpy(str[j+1],han);
                }
            }  
        for(i=0;i<n;i++)
    	{
    		printf("%s",str[i]);
            fprintf(fp,"%s ",str[i]);
        }
        if(fclose(fp)){
        	printf("Can not close the file!
    ");
        	exit(0);
    	}
        
     return 0;
    }
    
    

    3、流程图:

    4、调试过程中遇到问题:

    问题1:不知道如何按一个一个的字符串输出。
    解决办法:网上查找到了strcpy可以用来替换字符串。

    5、运行结果截图:

    预习作业:

    完成情况截图:


    学习进度条:

    周/日期 这周所花的时间 代码行 学到的知识点简介 目前比较困惑的问题
    3/11~3/16 10小时 46行 可以同时利用一维数组和二维数组来解题,以及二维数组的使用。 二维数组的二组循环比较迷惑
    3/18~3/22 8小时 110 行 冒泡排序和选择排序有相似之处,冒泡找最大值或找最小值是重复比较的,而选择一步到位。 冒泡排序按书上哪种方法把最后一个if判断条件改成小于为什么不能按大到小的顺序输出
    3/25~3/29 11小时 69行 strcpy可以用来替换字符串 如何更快的输入字符以及能不能一个一个字符串的输入
  • 相关阅读:
    js常用方法收集
    Jquery的常用使用方法
    jQuery css()选择器使用说明
    解决IE6,边框问题
    HTML问题集锦及笔记
    我的第一个chrome扩展(3)——继续读样例
    我的第一个chrome扩展(0)——目标
    我的第一个chrome扩展(2)——基本知识
    我的第一个chrome扩展(1)——读样例,实现时钟
    2の奇妙用法
  • 原文地址:https://www.cnblogs.com/xht8657/p/10623112.html
Copyright © 2020-2023  润新知