C语言II博客做业01

这个做业属于哪一个课程 https://edu.cnblogs.com/campus/zswxy/CST2020-2
这个做业要求在哪里 https://edu.cnblogs.com/campus/zswxy/CST2020-2/homework/11757
这个做业的目标 <回顾上学期知识>
学号 <20208978>

2.1 题目:给定一个十进制正整数N,写下从1开始,到N的全部整数,而后数一下其中出现的全部“1”的个数。

例如:算法

N=2,写下1,2。这样只出现了1个”1“。编程

N=12,咱们会写下1,2,3,4,5,6,7,8,9,10,11,12。这样,1的个数是5。函数

问题是:学习

1.写出一个函数f(N),返回1到N之间出现的”1“的个数,好比f(12)=5;测试

2.知足条件”f(N)=N“的最大的N是多少?code

要求:
1.贴出代码图片,写出解题思路,列出测试数据(5分)

解题思路:
遍历1~N,统计每一个数1出现的个数,相加便获得全部1的个数。blog

N的值 1的个数
1 1
12 5
100 21
1000 301

2.给出不一样测试数据的运算时间,若是你的运算时间不变,说明你的测试数据不够大(5分)
图片

3.思考针对足够大的数据,如何减小运算时间,并给出在原有算法基础上的改进算法和改进思路。(10分)内存

虽然这个方法看似简单可是计算量比较大若是N的值比较大那么运算的时间就太长了,第二种方法经过N在不一样位数都有规律
从而改进,减小了计算量。N是个位数时,N >=1,那么f(N)= 1;N = 0,f(N)= 0若是要计算百位上1出现的次数,它要
受到3方面的影响:百位上的数字,百位一下(低位)上的数字,百位一上(高位)上的数字。若是百位上数字为0,百位上可
能出现1的次数由更高位决定若是百位上数字为1,百位上可能出现1的次数不只受更高位影响还受低位影响。若是百位上数字大
于1(2~9),则百位上出现1的状况仅由更高位决定,

2.2 将上题中多组测试数据写入文件,并给出测试程序以检测你的代码有没有问题,贴出你的代码、运行结果和文件内容。(5分)




2.3 用本身的语言回答两个问题,并给出所查阅资料的引用(10分)

1.什么是文件缓冲系统?工做原理如何?

文件缓冲区即系统在读写程序时在内存中开辟的数据源与数据目标中间的一个用于保存完整数据内容的缓冲区域。
目前C语言使用的文件系统分为缓冲文件系统(标准I/O)和非缓冲文件系统(系统I/O)。缓冲文件系统的特色是:
在内存开辟一个“缓冲区”,为程序中的每个文件使用,当执行读文件的操做时,从磁盘文件将数据先读入内存“缓
冲区”,装满后再从内存“缓冲区”依此读入接收的变量。执行写文件的操做时,先将数据写入内存“缓冲区”,待内存
“缓冲区”装满后再写入文件。所以当程序运行时虽然进行了写数据操做,可是若是写入的数据没有装满内存中的缓冲区,
就不会将数据写入到磁盘文件中。当程序运行结束后,系统就会将缓冲区中的数据写入到磁盘上的文件中,所以就能够
看到文件中的内容。

2.什么是文本文件和二进制文件?

1,二进制文件是把内存中的数据按其在内存中的存储形式原样输出到磁盘上存放,也就是说存放的是数据的原形式。

二、文本文件是把数据的终端形式的二进制数据输出到磁盘上存放,也就是说存放的是数据的终端形式。

2.4 请给出本周学习总结(15分)

1 学习进度条(5分)

周/时间 所花时间 代码行数 所学知识简介 目前比较迷茫的问题
第一周 15小时 500 了解文件操做 没讲太多目前还没啥问题

2 累积代码行和博客字数(5分)

3 学习内容总结和感悟(5分)

1,新的一学期要有新的计划,要总结上学期的不足,在这学期每次做业要认真完成。
不只只完成老师布置的任务,还要本身选择性的学习。勤加练习,多学,多问,多作,
2,其实对编程仍是挺感兴趣的,每次作完一个题的成就感,和作题时的思考的感受其实
都挺好的,挺充实的、
相关文章
相关标签/搜索