博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
第七周作业
阅读量:4949 次
发布时间:2019-06-11

本文共 3309 字,大约阅读时间需要 11 分钟。

这个作业属于哪个课程 c语言程序设计
这个作业要求在哪里
我在这个课程的目标是 指针得使用和返回
这个作业在那个具体方面帮助我实现目标 用指针解决函数问题
参考文献 c语言程序设计

6-2 每个单词的最后一个字母改成大写 (10 分)

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

函数接口定义:

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

裁判测试程序样例:

#include 
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("\nAfter changing: %s\n", chrstr);return 0;}/* 请在这里填写答案 */

输入样例:

my friend is happy

输出样例:

After changing:   mY frienD iS happY

实验代码:

void fun( char *p ){  char *j=p;  while(*j!='\0')  {    if(*(j+1)==' '&&(*j<='z'&&*j>='a'))    *j=*j-32;    j++;  }}

流程图:

1580722-20190412183420995-18289622.png

实验中遇到的问题:

本来以为没这么简单,做了好多想法但是后来看到别人的代码发现这样好些

实验结果:

1580722-20190412183821362-1693217515.png

如图所示的简易自动售货机,物品架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 -11 2 3 5 1 6 9 10 -1

输出样例:

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

实验代码:

#include
int main(){ int i,a1=0,a2=0,n,a[11]={0},b[11]={0,1,1,1,2,2,3,3,3,4,4}; char c[11][20]={"","Table-water","Table-water","Table-water","Coca-Cola","Milk","Beer","Oolong-Juice","Sprite","Oolong-Tea","Green-Tea"}; while(scanf("%d",&n)) { if(n==-1) break; else a1+=n; } while(scanf("%d",&n)) { if(n==-1) break; else a[n]++; } for(i=1;i<11;i++) if(a[i]) a2+=b[i]*a[i]; if(a2>a1) printf("Insufficient money"); else { printf("Total:%dyuan,change:%dyuan\n",a1,a1-a2); for(i=1;i<11;i++) if(a[i]) printf("%s:%d;",c[i],a[i]); }}

流程图:

1580722-20190412185537471-1975299163.png

实验中遇到的问题:

开始的时候老是输出错误,但是在c++上能运行后来重新写了一次就对了

运行结果:

1580722-20190412190009279-417713895.png

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'都被删除)

实验代码:

#include
void delchar(char *ajk,char c){ int i=0; char *q; for(q=ajk;*q!='\0';q++) { if(*q==c) continue; else { *(ajk+i)=*q; i++; } } *(ajk+i)='\0';}int main(){ int n,i,j; char a[1005],b; scanf("%d",&n); getchar(); for(i=0;i

流程图:

1580722-20190412191840278-579211164.png

实验结果:

1580722-20190412191909240-710226093.png

学习总结:

周/日期 这周所花的时间 代码行 学到的知识点简介 目前比较迷惑的问题
3.3-3.9 3h 32 如何在Dev C++中写入文件并打开执行命令
3.10-3.16 5h 75 用指针打开文件 二维数组
3.17-3.23 6h 112 选择排序 冒泡排序的方法
3.24-3.30 5h 97 冒泡排序以及字符串使用 冒泡排序与选择排序的区
4.2-4.6 3h 40 指针返回多个函数的值 *和&的变化和指针传变量地址的问题
4.6-4.14 5h 201 冒泡排顺序 指针和数组之间的关系

结对编程:

没有结对 “ _ "
学习感悟:
没事多写写代码,多动一下脑子

转载于:https://www.cnblogs.com/lcj5657/p/10698042.html

你可能感兴趣的文章
详解软件工程之软件测试
查看>>
WCF(二) 使用配置文件实现WCF应用程序
查看>>
【CodeForces 803 C】Maximal GCD(GCD+思维)
查看>>
python 去掉换行符或者改为其他方式结尾的方法(end='')
查看>>
数据模型(LP32 ILP32 LP64 LLP64 ILP64 )
查看>>
REST构架风格介绍:状态表述转移
查看>>
struct {0}初始化
查看>>
c++ operator
查看>>
apache 添加 ssl_module
查看>>
java小技巧
查看>>
POJ 3204 Ikki's Story I - Road Reconstruction
查看>>
getQueryString
查看>>
Servlet文件上传和下载的复习
查看>>
JavaScript笔记——正则表达式
查看>>
iOS PushMebaby
查看>>
网页消息类
查看>>
【BZOJ】2959: 长跑(lct+缩点)(暂时弃坑)
查看>>
日常一些出现bug的问题
查看>>
同时启动多个tomcat服务器
查看>>
怎么将iphone上的照片导出到本地文件
查看>>