• 第七周编程总结


    问题 回答
    这个作业属于那个课程 C语言程序设计II
    这个作业要求在哪里 https://edu.cnblogs.com/campus/zswxy/computer-scienceclass3-2018/homework/2938
    我在这个课程的目标是 理解并掌握指针和数组、函数和字符串的用法
    这个作业在那个具体方面帮助我实现目标 指针和字符串类题目的练习
    参考文献 《C语言程序设计》

    7-1 使用函数删除字符串中的字符 (10 分)
    输入一个正整数 repeat (0<repeat<10),做 repeat 次下列运算:

    输入一个字符串 str,再输入一个字符 c,将字符串 str 中出现的所有字符 c 删除。

    要求定义并调用函数delchar(str,c), 它的功能是将字符串 str 中出现的所有 c 字符删除,函数形参str的类型是字符指针,形参c的类型是char,函数类型是void。

    输入输出示例:括号内为说明,无需输入输出

    输入样例:

    3               (repeat=3)
    happy new year  (字符串"happy new year")
    a               (待删除的字符'a')
    bee             (字符串"bee")
    e               (待删除的字符'e')
    111211          (字符串"111211")
    1               (待删除的字符'1')
    

    输出样例:

    result: hppy new yer    (字符串"happy new year"中的字符'a'都被删除)
    result: b               (字符串"bee"中的字符'e'都被删除)
    result: 2               (字符串"111211"中的字符'1'都被删除)
    

    2.实验代码

    #include<stdio.h>
    void delchar(char str[],char c);
    int main()
    {
        int repeat;
        char str[80],c;
    
        scanf("%d
    ",&repeat);  //要加换行符 
        while(repeat--)
        {
            gets(str);  //输入字符串 
            scanf("%c",&c); 
            printf("result: ");
            delchar(str,c);//调用函数 
        }
    
        return 0;
    }
    
    void delchar(char str[],char c)  //str[]相当于*p
    {
        while(*str!='')  //不为空字符 
        {
            if(*str!=c)  //字符不相等 
            {
                putchar(*str);  //输出字符 ,要注意puts()是输出字符串,putchar()是输出一个字符 
            }
            str++;  //移动到下一个字符 
        }
    }
    

    3。运行结果图

    4.流程图

    5.出现的问题及解决方案
    问题一:开始做题时不能太理解题目意思,比如删除字符串str中的字符c含义,以及字符串为何要用正整数repeat表示等
    解决方案:百度了一下题目中关键词的含义及其函数用法,翻看资料阅读了一下相关题目的做法
    问题二:将形参与实参的概念混淆了,导致在编写代码时出现了类型不匹配错误
    解决方案:向同学询问了错误原因,并翻书巩固了形参与实参的特点、区别、用途

    6-2 每个单词的最后一个字母改成大写 (10 分)
    函数fun的功能是:将p所指字符串中每个单词的最后一个字母改成大写。(这里的“单词”是指由空格隔开的字符串)。

    函数接口定义:

    void fun( char *p );
    

    其中 p 是用户传入的参数。函数将 p所指字符串中每个单词的最后一个字母改成大写。

    裁判测试程序样例:

    #include <stdio.h>
    void fun( char *p );
    int main()
    {
     char chrstr[64];  int d ;
      gets(chrstr);
      d=strlen(chrstr) ;
      chrstr[d] = ' ' ;
      chrstr[d+1] = 0 ;
      fun(chrstr);
      printf("
    After changing:   %s
    ", chrstr);
    return 0;
    }
    

    /* 请在这里填写答案 */
    输入样例:

    my friend is happy
    

    输出样例:

    After changing:   mY frienD iS happY
    

    2.实验代码:

    void fun(char *p)
    {
      for(;*p!='';p++)
      {
        if(*p!=' '&&*(p+1)==' ')
          *p=*p-32;
      }
    }
    

    3.运行结果图:

    4.流程图:

    5.出现的问题及解决方案
    问题:对内部结构有点迷茫
    解决方案:百度并查阅资料

    7-2 自动售货机 (30 分)
    如图所示的简易自动售货机,物品架1、2上共有10样商品,按顺序进行编号分别为1-10,标有价格与名称,一个编号对应一个可操作按钮,供选择商品使用。如果物架上的商品被用户买走,储物柜中会自动取出商品送到物架上,保证物品架上一定会有商品。用户可以一次投入较多钱币,并可以选择多样商品,售货机可以一次性将商品输出并找零钱。

    1.jpg

    用户购买商品的操作方法是:

    (1)从“钱币入口”放入钱币,依次放入多个硬币或纸币。钱币可支持1元(纸币、硬币)、2元(纸币)、5元(纸币)、10元(纸币),放入钱币时,控制器会先对钱币进行检验识别出币值,并统计币值总额,显示在控制器显示屏中,提示用户确认钱币放入完毕;

    (2)用户确认钱币放入完毕,便可选择商品,只要用手指按对应商品外面的编号按钮即可。每选中一样商品,售货机控制器会判断钱币是否足够购买,如果钱币足够,自动根据编号将物品进行计数和计算所需钱币值,并提示余额。如果钱币不足,控制器则提示“Insufficient money”。用户可以取消购买,将会把所有放入钱币退回给用户。

    输入格式:
    先输入钱币值序列,以-1作为结束,再依次输入多个购买商品编号,以-1结束。

    输出格式:
    输出钱币总额与找回零钱,以及所购买商品名称及数量。

    输入样例:

    1 1 2 2 5 5 10 10 -1
    1 2 3 5 1 6 9 10 -1
    

    输出样例:

    Total:36yuan,change:19yuan
    Table-water:2;Table-water:1;Table-water:1;Milk:1;Beer:1;Oolong-Tea:1;Green-Tea:1;
    

    2.实验代码:

    int main ()
    {
        int sum1=0,sum2=0;
        int i,money=0,number[1000];
        for(i=0;i<=10;i++)
        {
            scanf("%d",&money);
            if(money==-1)
              break;
            else
              sum1+=money;
        }
        for(i=0;number[i-1]!=-1;i++){
            scanf("%d",&number[i]);
        }
        int goods[10];
        char name[10][20]={"Table-water","Table-water","Table-water","Coca-Cola","Milk","Beer","Orange-Juice","Sprite","Oolong-Tea","Green-Tea"};
        for(i=0;number[i]!=-1;i++){
            switch(number[i]){
                case 1: goods[0]++;sum2+=1;break;
                case 2: goods[1]++;sum2+=1;break;
                case 3: goods[2]++;sum2+=1;break;
                case 4: goods[3]++;sum2+=2;break;
                case 5: goods[4]++;sum2+=2;break;
                case 6: goods[5]++;sum2+=3;break;
                case 7: goods[6]++;sum2+=3;break;
                case 8: goods[7]++;sum2+=3;break;
                case 9: goods[8]++;sum2+=4;break;
                case 10: goods[9]++;sum2+=4;break;
            }
        }
        if(sum1>sum2){
            printf("Total:%dyuan,change:%dyuan
    ",sum1,sum1-sum2);
            for(i=0;i<10;i++){
                if(goods[i]!=0)
                    printf("%s:%d;",name[i],goods[i]);
            } 
        }
        else
            printf("Insufficient money");
        
        return 0;
    }
    

    3.运行结果图:

    4.流程图:

    总结图

  • 相关阅读:
    217. Contains Duplicate (leetcode)
    242. Valid Anagram(leetcode)
    JVM的逃逸分析
    有 a
    Maven 项目管理从未如此通畅
    Spring学习手札(四)谈谈Spring Bean的生命周期及作用域
    Spring学习手札(三)理解IoC 拯救不开心
    Spring学习手札(二)面向切面编程AOP
    Spring学习手札(一)
    Java提供了哪些IO方式?IO, BIO, NIO, AIO是什么?
  • 原文地址:https://www.cnblogs.com/wmf0616/p/10697621.html
Copyright © 2020-2023  润新知