第七周作业

第七周作业

||||
|:--|:--|:--|:--|:--|:--|:--|:--|:--|:--|
|课程:|C语言程序设计II|
|作业要求:|19大一下期七周|
|课程目标:|能够独立进行简单程序编辑,团队进行较大型程序设计|
|作业目标:|对指针、函数进一步加深了解|
|参考文献:|C语言程序设计II|

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("\nAfter changing:   %s\n", chrstr);
return 0;
}

/* 请在这里填写答案 */
输入样例:
my friend is happy
输出样例:
After changing: mY frienD iS happY

程序

void fun( char *p )
{
	int i=0; 
	while(*(p+i)!=0)
	{
		if(*(p+i)==' '&&*(p+i-1)!=' ')
		{
			*(p+i-1)=*(p+i-1)-32;
		}
		i++;
	}
} 

设计思路

判断空格的前一个是否是字母是则变换不是就不变,变的化由 A S C I I 码知小写变大写要减去32

3)本题调试过程碰到问题及解决办法

7-2 自动售货机 (30 分)

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

程序

#include<stdio.h>
int main()
{
	int money,amount=0,number,total=0,a[10]={0},i;
	scanf("%d",&money);
	while(money>0)
	{
		total+=money;
		scanf("%d",&money);
	} 
	scanf("%d",&number);
	while(number>0)
	{ 
		switch(number)
		{
			case 1:money=1;a[0]++;break;
			case 2:money=1;a[1]++;break;
			case 3:money=1;a[2]++;break;
			case 4:money=2;a[3]++;break;
			case 5:money=2;a[4]++;break;
			case 6:money=3;a[5]++;break;
			case 7:money=3;a[6]++;break;
			case 8:money=3;a[7]++;break;
			case 9:money=4;a[8]++;break;
			case 10:money=4;a[9]++;break;
		}
		amount+=money;
		scanf("%d",&number); 
	}
	
	if(amount>total)
		printf("Insufficient money");
	else
	{
		printf("Total:%dyuan,change:%dyuan\n",total,total-amount);
		for(i=0;i<10;i++)
		{
			switch(i)
			{
				case 0:if(a[i]!=0)printf("Table-water:%d;",a[i]);break;
				case 1:if(a[i]!=0)printf("Table-water:%d;",a[i]);break;
				case 2:if(a[i]!=0)printf("Table-water:%d;",a[i]);break;
				case 3:if(a[i]!=0)printf("Coca-Cola:%d;",a[i]);break;
				case 4:if(a[i]!=0)printf("Milk:%d;",a[i]);break;
				case 5:if(a[i]!=0)printf("Beer:%d;",a[i]);break;
				case 6:if(a[i]!=0)printf("Orange-Juice:%d;",a[i]);break;
				case 7:if(a[i]!=0)printf("Sprite:%d;",a[i]);break;
				case 8:if(a[i]!=0)printf("Oolong-Tea:%d;",a[i]);break;
				case 9:if(a[i]!=0)printf("Green-Tea:%d;",a[i]);break;
			}
		}
	}
}

设计思路

输入并计算钱,然后计算物品总价, 比较,进行输出

3)本题调试过程碰到问题及解决办法

-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<stdio.h>
void delchar(char *q,char c);
int main ()
{
	int n;
	char x,str[100],c;
	scanf("%d",&n);
	getchar();
	for(int i=0;i<n;i++){
		
		gets(str);
		c=getchar();
		printf("result: ");
		delchar(str,c);
	}
	return 0;
}

void delchar(char *p,char c)
{
	for(int i=0;*(p+i)!='\0';i++){
		if(*(p+i)!=c)
			printf("%c",*(p+i));
	}
	printf("\n");
}

3)本题调试过程碰到问题及解决办法

所用时间太长

4).运行结果截图

问题:

.用时3小时30分钟,30用与写与调试,3小时阅读思考

心得:指针可以减少变量的使用

|||||||
|:--|:--|:--|:--|:--|:--|:--|:--|:--|:--|:--|
|周/日期|这周所花的时间|代码行|学到的知识点简介|目前比较迷惑的问题|
|3/2-3/8|2天|300|指针、文件、数组|getchar()不知道|
|3/9-3/13|1天|200|指针|文件|
|3/13-3/22|2天|300|数组|对代码高效性欠缺|
|3/23-3/29|3天|400|数组|对文件不熟悉|
|3/29-4/5|2天|400|指针|对文件数据调用不熟悉|
|4/5-4/12|2天|500|指针|对文件数据调用不熟悉|

posted @ 2019-04-12 21:04  张三告  阅读(104)  评论(1编辑  收藏  举报