作业头 ![](https://img2018.cnblogs.com/blog/1580389/201904/1580389-20190412222436734-332728034.png) 函数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){ int i; for (i=0;*(p+i)!='0';i++) if (*(p+i+1)==' ') *(p+i)=*(p+i)-'a'+'A'; } 实验思路 ![](https://img2018.cnblogs.com/blog/1580389/201904/1580389-20190412222600816-1005661094.png) 3)本题做对过程碰到问题及解决办法 for循环里面不知道循环条件是什么,后面仔细审题后做出来了。 正确截图 ![](https://img2018.cnblogs.com/blog/1580389/201904/1580389-20190412222658212-850953795.png) 7-2 自动售货机 (30 分) 如图所示的简易自动售货机,物品架1、2上共有10样商品,按顺序进行编号分别为1-10,标有价格与名称,一个编号对应一个可操作按钮,供选择商品使用。如果物架上的商品被用户买走,储物柜中会自动取出商品送到物架上,保证物品架上一定会有商品。用户可以一次投入较多钱币,并可以选择多样商品,售货机可以一次性将商品输出并找零钱。 用户购买商品的操作方法是: (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; 实验代码 # include int main(void) { int i, m, change, n, a[20], b[20]; int d[10] = {0,0,0,0,0,0,0,0,0,0}; char c[10][30] = {"Table-water","Table-water","Table-water","Coca-Cola","Milk","Beer","Orange-juice","Sprite","Oolong-Tea","Green-Tea"}; int x=0, y, f, flag = 0; i = 0; scanf("%d", &f); while((f != -1)&&(f <= 10)) { x = x + f; scanf("%d",&f); //对钱进行输入 } i = 0; scanf("%d", &b[i]); while(b[i] != -1){ i++; n = i; scanf("%d", &b[i]); //对商品编号进行输入 } y = 0; for(i = 0; i< n;i++){ switch(b[i]){ case 1:case 2:case 3:y = y + 1;break; case 4:case 5:y = y + 2;break; case 6:case 7:case 8:y = y + 3;break; case 9:case 10:y = y + 4;break; default : break; } //对所选商品的价格计算 } if(x < y){ printf("Insufficient money"); } else{ flag = 1; } if(flag == 1){ change = x - y; printf("Total:%dyuan,change:%dyuan\n",x , change); //输出钱币总额与找回零钱 for(i = 0; i< 10;i++){ switch(b[i]){ case 1: d[0]++;break; case 2: d[1]++;break; case 3: d[2]++;break; case 4: d[3]++;break; case 5: d[4]++;break; case 6: d[5]++;break; case 7: d[6]++;break; case 8: d[7]++;break; case 9: d[8]++;break; case 10: d[9]++;break; default:break; //对一种商品多次选择 } } for(m = 0; m void delchar(char *str,char *c); int main(void) { int n,j,i,k,m,repeat; char str[1000],c; scanf("%d",&repeat); for(i=0;i<repeat;i++){ scanf("%c",&str[0]); for(j=0;;j++){ scanf("%c",&str[j]); if(str[j]=='\n'){ break; } } scanf("%c",&c); delchar(str,&c); printf("result: "); for(j=0;;j++){ if(str[j]=='\n'){ break; } printf("%c",str[j]); } printf("\n"); } return 0; } void delchar(char *str,char *c) { int i,j,k,l,m,n; for(i=0;str[i]!='\n';i++){ if(str[i]==*c){ for(j=i;str[j]!='\n';j++){ str[j]=str[j+1]; } i=i-1; } } } 3)本题做对过程碰到问题及解决办法 这个题目我自己看了很久也没有做出来,最后是问黄洛成才将这个题目勉强做出来了。 正确截图 ![](https://img2018.cnblogs.com/blog/1580389/201904/1580389-20190412223213110-166173985.png) 学习进度条 ![](https://img2018.cnblogs.com/blog/1580389/201904/1580389-20190412223311745-166754791.png) 折线图 ![](https://img2018.cnblogs.com/blog/1580389/201904/1580389-20190412223352791-131095398.png) 学习感悟 越学到后面感觉越难,自己的基础真的太low了,有些题目就算是看懂了,也不知道怎么用代码去表示。今后努力学习,不懂就问为什么。 结对编程 此次结对编程还行,队友很是耐心的教了我指针,还有基础题里面的编程题,从第一个函数题里面又学到了一些东西。