这篇博客是学习传智播客c++教程的作业,通过在网上进行搜集来完成,但是网上有相似的代码,但是结果总是有点问题,所以本文写了这篇记录下。

#include <stdio.h>
#include <stdlib.h>
#include <errno.h>
#include <string.h>
#include <unistd.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>
//3.1去除字符串右边的空格
char *TrimStrR(char *SrcStr)
{
if (SrcStr == NULL)
{
printf("TrimStrR function is error!");
return NULL;
}
int i = ;
int iLen = strlen(SrcStr);
for(i = (iLen -);i>=;i--)
{
if(SrcStr[i] == ' ')
SrcStr[i] = ;
else
break;
}
return SrcStr;
}
//3.2去掉字符串左边的空格
char *TrimStrL(char *SrcStr)
{
if (SrcStr == NULL)
{
printf("TrimStrR function is error!");
return NULL;
}
if(SrcStr[] != ' ')
{
return SrcStr;
}
int i = ;
int iLen = strlen(SrcStr);
if(iLen == )
{
return SrcStr;
}
char *stemp = (char*)malloc(iLen+);
memset(stemp,,iLen+);
memcpy(stemp,SrcStr,iLen);
for(i = ;i<iLen;i++)
{
if(SrcStr[i] != ' ')
{
strcpy(stemp,SrcStr+i);
break;
}
}
strcpy(SrcStr,stemp);
free(stemp);
return SrcStr;
}
//3.3解析带等号的字符串并去掉字符串传尾部空格
void ParseValueStr(char *Des,char* SrcStr)
{
int iLen = strlen(SrcStr);
if(iLen == )
{
return ;
}
if((SrcStr[iLen -] == '\n')||(SrcStr[iLen -] == '\r'))
{
SrcStr[iLen -] = '\0';
}
if(iLen > )
{
if((SrcStr[iLen -] == '\n')||(SrcStr[iLen -] == '\r'))
{
SrcStr[iLen -] = '\0';
}
}
TrimStrR(SrcStr);
int i = ;
for(i= ;i<iLen;i++)
{
if((*SrcStr) == '=')
{
strcpy(Des,++SrcStr);
break;
}
++SrcStr;
}
TrimStrL(Des);
}
//3.4计算数组buf中的最大值,参数bufsize为参数buf的元素数量
int max(const int *buf,const int bufsize)
{
int tmp = buf[];
int i = ;
for(i = ;i<bufsize;i++)
{
if(tmp <= buf[i])
tmp = buf[i];
}
return tmp;
}
float avg(const int *buf,const int bufsize)
{
float sum = ;
int i = ;
for(i = ;i<bufsize;i++)
{
sum += buf[i];
}
return sum/bufsize;
}
int min(const int *buf,const int bufsize)
{
int tmp = buf[];
int i = ;
for(i = ;i<bufsize;i++)
{
if(buf[i] == )
continue;
if(tmp >= buf[i])
tmp = buf[i];
}
return tmp;
}
int main(int args, char*argc[])
{
if (args < )
{
printf("parameters is error!\n");
}
char buf[];
char value[];
int values[];
memset(values,,sizeof(values));
FILE* fp = fopen(argc[], "r");
int i = ;
int j = ;
while(!(feof(fp)))
{
memset(buf,,sizeof(buf));
memset(value,,sizeof(value));
fgets(buf,sizeof(buf),fp);
ParseValueStr(value,buf);
values[i] = atoi(value);
i++; }
for(j = ;j<i-;j++)
{
printf("%d\n",values[j]);
}
fclose(fp);
printf("最大值:%d\n",max(values,i));
printf("最小值:%d\n",min(values,i));
printf("平均值:%f\n",avg(values,i));
return ;
}

下面是运行后的结果:

作业训练------通过读取c.txt文件中的内容等号右值,并将右值的最大值、最小值、平均值打印到屏幕上。的更多相关文章

  1. Flex读取txt文件中的内容(三)

    Flex读取txt文件中的内容 1.设计源码 LoadTxt.mxml: <?xml version="1.0" encoding="utf-8"?> ...

  2. Flex读取txt文件中的内容(二)

    Flex读取txt文件中的内容 自动生成的文件 LoadTxt-app.xml: <?xml version="1.0" encoding="utf-8" ...

  3. Flex读取txt文件中的内容(一)

    Flex读取txt文件中的内容 phone.txt: 13000003847 13000003848 13000003849 13000003850 13000003851 13000003852 1 ...

  4. Flex读取txt文件中的内容报错

    Flex读取txt文件中的内容 1.具体错误如下 2.错误原因 读取文件不存在 var file:File = new File(File.applicationDirectory.nativePat ...

  5. 向txt文件中写入内容(覆盖重写与在末尾续写+FileOutputStream与FileWriter)(转发:https://blog.csdn.net/bestcxx/article/details/51381460)

    !!!! 读取txt文件中的内容 import java.io.BufferedReader; import java.io.File; import java.io.FileReader; /** ...

  6. 代码实现:定义一个文件输入流,调用read(byte[] b)方法,将a.txt文件中的内容打印出来(byte数组大小限制为5)

    package com.loaderman.test; import java.io.ByteArrayOutputStream; import java.io.FileInputStream; im ...

  7. 按行读取TXT文件中的内容

    public Dictionary<int, string> GetDicFromLog() { try { StreamReader sr = new StreamReader(file ...

  8. js读取本地txt文件中的json数据

    list.txt内容 [ {"optionKey":"1", "optionValue":"Canon in D"}, ...

  9. Java中读取txt文件中中文字符时,出现乱码的解决办法

    这是我写的一个Java课程作业时,遇到的问题. 问题描述: 我要实现的就是将txt文件中的内容按一定格式读取出来后,存放在相应的数组. 我刚开始运行时发现,英文可以实现,但是中文字符就是各种乱码. 最 ...

随机推荐

  1. HDU - 4810 - Wall Painting (位运算 + 数学)

    题意: 从给出的颜料中选出天数个,第一天选一个,第二天选二个... 例如:第二天从4个中选出两个,把这两个进行异或运算(xor)计入结果 对于每一天输出所有异或的和 $\sum_{i=1}^nC_{n ...

  2. Gym - 101670C Chessboard Dancing(CTU Open Contest 2017 找规律)

    题目:链接 思路: 多画出几个情况就可以找出规律来了 Knight (当大于2的时候只要两种颜色相间出现就可以了) King(当大于等于3的时候,总可以用四种形式来补色,具体如下)  Bishop(斜 ...

  3. (七)python3 切片

    切片:取一个 list 或 tuple 的部分元素是非常常见的操作 >>> L = ['Michael', 'Sarah', 'Tracy', 'Bob', 'Jack'] #笨办法 ...

  4. saltstack(二) master、minion常用配置选项

    master常用配置选项: interface: 指定bind的地址(默认0.) publish_port:指定发布端口(默认4505) ret_port: 指定结果返回端口,与minion配置文件的 ...

  5. java 中序列化(Serializable)

    18年5月份,在毕业快一年的时候,我终于把自己从研发助理偏向行政打杂,偶尔写一些前端代码的处境,回归到了初衷-安安静静写前后端代码的小小程序员~过程中的心酸也就不在这里吐啦,毕竟我是小太阳,永不熄灭的 ...

  6. 百练4152:最佳加法表达式(dp+高精度)

    描述 给定n个1到9的数字,要求在数字之间摆放m个加号(加号两边必须有数字),使得所得到的加法表达式的值最小,并输出该值.例如,在1234中摆放1个加号,最好的摆法就是12+34,和为36 输入有不超 ...

  7. [luoguP1282] 多米诺骨牌(DP + 背包)

    传送门 将问题转换成分组背包,每一组有上下两个,每一组中必须选则一个,上面的价值为0,下面的价值为1,求价值最小 因为要求上下两部分差值最小,只需从背包大小为总数 / 2 时往前枚举,找最小答案即可. ...

  8. java虚拟机(二)--垃圾收集器与内存分配策略

    1.判断对象是否存活的算法: 1.1.引用计数算法:给对象添加一个引用计数器,每当有一个地方引用他时,计数器+1,当引用失效时,计数器-1,任何时刻计数器为0的对象就是不可能再被引用的,但是他很难解决 ...

  9. rest frame work纪念版代码

    models.py from django.db import models from pygments.lexers import get_all_lexers from pygments.styl ...

  10. 次小生成树 判断 unique MST

    Given a connected undirected graph, tell if its minimum spanning tree is unique. Definition 1 (Spann ...