Coursera课程笔记----计算导论与C语言基础----Week 6
理性认识C程序 导论(Week 6)
明确学习进度
讲课内容 感性➡️理性➡️函数➡️指针等
作业练习 初级阶段 ➡️正常作业练习
C语言的由来
程序设计语言的分类
- 低级语言之机器语言 001010101001……
- 低级语言之汇编语言 load 0 a 数据装入寄存器0……
- 高级语言之C语言 d = a * b + c 顶机器语言一连串10101010……
高级程序设计语言
1954-1956——John Backus——FORTRAN(FORmula TRANslation)——数学计算领域
1960——Alan J. Perlis——A语言(Algol 60)——计算科学里程碑
1963——剑桥大学——CPL(Combined Programming Language)——规模太大难以实现
1967——Matin Pichards——BCPL(Basic CPL)
1970——贝尔实验室 Ken Thompson——B语言(简化BCPL)——UNIX
1972-1973——Dennis Ritchie& Ken Thompson——C语言(完善发展B语言)——重写UNIX
C语言的版本
- K&R C——第一版——1978
- ANSI C 和 ISO C——1989ANSI——1009ISO——两者标准化组织
- C99——1999
- C11——2011
特别情况
- C语言规范定义的非常宽泛
- long型数据长度不短于int型
- short型不长于int型
- 导致了:
- 相同程序在不同编译器上具有不同解释
- 相同的程序在不同平台上运行结果不同
- 例如,整形变量定义;对++、--的解释;输入输出赋值顺序的不同;浮点数计算精度不同……
From C to C++
1979——贝尔实验室 Bjarne Stroustrup——给C加入面向对象的特性——C with Classes——C++
1985——The C++ Programming Language 第一版
1998——C++国际标准
2011——C++2011标准
C or C++
C++语言支持了C语言所有的特性,我们要在C++环境中学习C语言的部分。
如何学习一门编程语言(语法知识)
- 语言的种类千差万别,但是基本成分不外乎四种
- 数据成分:有哪些数据类型?如何使用?
- 运算成分:有哪些运算符号?如何使用?
- 控制成分:三种类型的控制语句是如何写的?
- 传输成分:在程序中如何输入和输出数据?
作业题
Quiz 1 细菌实验分组
#include <iostream>
using namespace std;
int main()
{
int n;//n为细菌的数量
int id[100];//细菌的编号
double rate[100];//细菌的繁殖率
cin>>n;
for(int i = 0; i < n; i++)
{
int initial,final;
cin >> id[i] >> initial >> final;
rate[i] = (double)final / initial;
}
//排序
for (int i = 0; i < n; i++)
{
for(int j = 0; j < n - i - 1; j++)
{
if(rate[j+1] > rate[j])
{
int tmpID = id[j];
id[j] = id[j+1];
id[j+1] = tmpID;
double temRate = rate[j];
rate[j] = rate[j+1];
rate[j+1] = temRate;
}
}
}
//记录最大的差和最大差的下标
double maxDiff = 0;
int maxDiffIndex = 0;
for (int i = 0; i < n - 1; i++) {
double diff = rate[i] - rate[i + 1];
if(maxDiff < diff)
{
maxDiff = diff;
maxDiffIndex = i;
}
}
//输出繁殖率较大的那组细菌
cout<< maxDiffIndex + 1 <<endl;
for (int i = maxDiffIndex; i >=0 ; i--) {
cout<<id[i]<<endl;
}
cout<< n - maxDiffIndex - 1 << endl;
for (int i = n - 1; i >= maxDiffIndex + 1 ; i--) {
cout<<id[i]<<endl;
}
return 0;
}
Quiz 2 苹果和虫子
#include <iostream>
using namespace std;
int main()
{
int numApple, bugSpeed, hour;
cin>>numApple>>bugSpeed>>hour;
int numEat = hour / bugSpeed;
if(numEat - numApple > 0)
cout<<"0"<<endl;
else if (hour % bugSpeed == 0)
cout<< numApple - numEat << endl;
else
cout<<numApple - numEat - 1 <<endl;
return 0;
}
Quiz 3 大象喝水
#include <iostream>
using namespace std;
int main()
{
int height, radius;
cin>>height>>radius;
double volume = 3.1415926*radius*radius*height;
int num = 20*1000 / volume;
cout<<num + 1 << endl;
return 0;
}
Quiz 4 最高的分数
#include <iostream>
using namespace std;
int main()
{
int numStu, stu[100];
cin>>numStu;
for (int i = 0; i <numStu ; i++) {
cin>>stu[i];
if(i != 0 && stu[i] > stu[0])
stu[0] = stu[i];
}
cout<<stu[0]<<endl;
}
Quiz 5 最大奇数与最小偶数之差的绝对值
#include <iostream>
using namespace std;
int main()
{
int num[6], maxOdd = 1, numAbs, minEven = 101;
for (int i = 0; i < 6; i++)
cin>>num[i];
for (int i = 0; i < 6; i++) {
if(num[i] % 2 == 0 && num[i] < minEven)
minEven = num[i];
if(num[i] % 2 == 1 && num[i] > maxOdd)
maxOdd = num[i];
}
if(maxOdd - minEven < 0)
numAbs = minEven - maxOdd;
else numAbs = maxOdd - minEven;
cout << numAbs << endl;
return 0;
}
Quiz 6 分离整数的各个数位
#include <iostream>
using namespace std;
int main()
{
int num,a,b,c;
cin>>num;
a = num / 100;
b = (num - a * 100) / 10;
c = num % 10;
cout<<a<<"\n"<<b<<"\n"<<c<<endl;
}
Coursera课程笔记----计算导论与C语言基础----Week 6的更多相关文章
- Coursera课程笔记----计算导论与C语言基础----Week 8
C语言中的运算成分(Week 8) 赋值运算符 "="赋值运算符 给赋值号左边的变量赋予数值 在变量定义的同时可以为变量赋初值 要点一:两面类型不同 若=两边的类型不一致,赋值时要 ...
- Coursera课程笔记----计算导论与C语言基础----Week 7
C语言中的数据成分(Week7) 内存 把内存想象成长带,带子上有许多方格,每个方格有8位(8bit) 2^10 = 1024 1B = 8 b 1KB = 1024Byte MB.GB.TB.PB- ...
- Coursera课程笔记----计算导论与C语言基础----Week 4
感性认识计算机程序(Week 4) 引入 编程序 = 给计算机设计好运行步骤 程序 = 人们用来告诉计算机应该做什么的东西 问题➡️该告诉计算机什么?用什么形式告诉? 如果要创造一门"程序设 ...
- Coursera课程笔记----计算导论与C语言基础----Week 2
计算机的历史与未来(Week 2) 计算机历史 早期计算机:手工计算器➡️机械计算器➡️计算机原型 现代计算机:电子管计算机➡️晶体管计算机➡️集成电路计算机➡️超大规模集成电路 早期的手工计算辅助工 ...
- Coursera课程笔记----计算导论与C语言基础----Week 9
C语言中的控制成分(Week 9) 计算机程序的基本结构 任何具有单入口单出口的程序,都可以用顺序结构.分支结构.循环结构来表达 分支语句 在执行if语句前,先对表达式求解 if()内可以是任意的数值 ...
- Coursera课程笔记----计算导论与C语言基础----Week 3
存储程序式计算机 冯·诺伊曼式计算机 "关于EDVAC的报告草案" 组成:控制器(协调工作).运算器(算数&逻辑运算).存储器(存储操作信息和中间结果).输入设备.输出设备 ...
- Coursera课程笔记----计算导论与C语言基础----Week 1
计算机的基本原理(Week 1) 第一次数学危机 公元前500年,毕达哥拉斯学派,他们相信数是万物的本源:一切数均可表示成整数或者整数之比 然而毕达哥拉斯证明了勾股定理,某些直角三角形的三边比不能用整 ...
- Coursera课程笔记----计算导论与C语言基础----Week 12
期末编程测试(Week 12) Quiz1 判断闰年 #include <iostream> using namespace std; int main() { int year; cin ...
- Coursera课程笔记----计算导论与C语言基础----Week 11
C程序中的字符串(Week 11) 字符数组 所有的字符串,都是以\0结尾的 只能在数组定义并初始化的时候:char c[6] = "China"; 不能用赋值语句将一个字符串常量 ...
随机推荐
- 经典算法之归并排序——python和JS实现
前言 文的文字及图片来源于网络,仅供学习.交流使用,不具有任何商业用途,版权归原作者所有,如有问题请及时联系我们以作处理. 作者:韩忠康 PS:如有需要Python学习资料的小伙伴可以加点击下方链接自 ...
- F - Pearls HDU - 1300
简单dp. 题目大意:有n种珍珠,这n种珍珠有不同的需求量,不同的价格,价格越高,质量越高,在购买每一种珍珠时,都需要在原来的基础上多买10个.也就是说如果需要买x种珍珠,那就要付x+10个的钱.每一 ...
- 65535与TCP连接数的关系测试结论
首先说结论: .是否有关系 .有关系 对于客户端 -.对于客户端来说,只有65535,因为根据TCP四元组的sport来说,sport只有16位,所以(2^16)-1是65535.也就是最多有6553 ...
- python3+selenium3自动化1——元素定位
1.selenium的webdriver提供了八种基本的元素定位方法 打开浏览器 driver = webdriver.Chrome() driver.get('https://www.baidu.c ...
- python3 xlwt,csv学习
前言 对于抓取一些站点分析然后指纹识别的时候可能用到到它.所以学习下.这里就记录一些最基本的感觉有用的. xlwt 基本创建 demo: #coding=utf- import xlwt yunyin ...
- Upload-Labs 实验操作记录
0x01 安装 下载:https://github.com/c0ny1/upload-labs 环境:简单搭建phpstudy环境即可,记得在upload-labs根目录下创建该文件夹 0x02 文件 ...
- [linux][nginx] 通过nginx扩展nginx-rtmp-module简单做了一个流媒体直播
做的过程出现很多问题,环境其实就需要nginx就可以,然后就是在播放的问题,m3u8的格式,mac直接访问就支持,苹果系统原生H5支持m3u8,还有就是手机直接访问也支持!但是其他其他系统PC端不支持 ...
- 使用dynamic 和MEF实现轻量级的 AOP 组件 (1)
转载https://www.cnblogs.com/niceWk/archive/2010/07/19/1780843.html AOP魔法 今天你AOP了吗?谈到AOP,总有一种神秘的感觉,人类对于 ...
- vnpy源码阅读学习(9)回到OptionMaster
回到OptionMaster 根据我们对APP调用的代码阅读,我们基本上知道了一个APP是如何被调用,那么我们回到OptionMaster学习下这个APP的实现. 看看结构 class OptionM ...
- ES6让字符串String增加了哪些好玩的特性呢?
确实因为现在天气变热了,所以一天天的这么写我也很累.所以如果阅读的时候有什么错误还请大家指出来,不好意思.学习永无止境. OK,今天继续讲解ES6系列知识 学过上一节的解构赋值就知道,ES6确实给我们 ...