鱼C论坛

 找回密码
 立即注册
查看: 1034724|回复: 42065

[课后作业] S1E2:第一个程序 | 课后测试题及答案

    [复制链接]
发表于 2015-11-16 15:05:01 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
《带你学C带你飞》第一季视频下载地址:传送门y$Uv|
KHFv!5jQRZh&_b,y.gewO9sT
测试题:版权属于:bbs.fishc.com
1gn"u-EU[+LVP9J;HNksM_)
0. 为什么我们说计算机其实是“二傻子”?4g<+05O
&hHAg@^CzFWm?R[ QioL
S;>inEqox,j"f8&v<cs?'HC7-B
1. CPU 唯一认识的语言是什么语言?MK}t%#@('<
|!X*oI)}b^m;U79zB1= Mn$.pFZ
S>uyOd{AT:YDK=R8q_x)1C0L
2. C 语言编写的源代码转换为汇编语言的过程叫什么?lZh%;}Umf
pNGKc"&4n<^}0{ke,qUY
+~1q0-SJD=,;m|>"?L$zh5
3. 编译型语言和解释型语言的本质区别是什么?H2-&{Lk;G>
UY36-Si2^chaH)j!QZdn5:"oP`T
16E(Xt_g~>vA9cR|kJmV]:u
4. 在 Linux 系统上用 C 语言编译的可执行程序,是否能在 Windows 系统上执行?}s.9?jZ{
SK"%)7sT[w|~0('RuJXW*@r=y!jehU
hKS?m%O{*#q+MDY.`znwB
5. 解释型编程语言是如何实现跨平台的?TKu@.m fe"
31.iV&Kb=E+4ZMUIjc0Hk
kn-e)SCW3,+4U yQ_:'P!YID
6. 莫斯密码的原理其实是什么?来自:bbs.fishc.com
4#$k,v6+>&uXPEs.}<B{i_e8]!WM
4!5}(0W1#[>dt^NCw.e_`)U-L@9xGR
7. 视频中小甲鱼“故弄玄虚”的那段密文还原后是什么内容(中文)?RY(2Hqab0P
Es#w2|l)zBLnqg+@[Mi;'fP
图片4.png
A1m4p>&9PLI8Sk#BnwY2Wag^boF
Lpvz{w5q%>4?DWh}lPGrBg';
动动手:来自:bbs.fishc.com
kN,x;y4Dg=_m?'LR")ET]K0Z-Vz
不是说一个合格的程序员需要累积 10 万行的代码量嘛!
{_XKJZqu}(8%hNz;Uow+f,
那么这节课的动动手环节就让大家写一个计算代码量的程序吧~Jtg*r[
x=)*A($I4uf:%GSTX^;-&tK
Powered by bbs.fishc.com
;vOCP,n6Z) yTq(0.K=Y"Ne
程序要求:统计当前目录及所有子目录下,C 语言源文件的代码总行数。xyi,B%
Va>O4Llmd7J]9Fx2CHnWgy
怎么写??????????????????E4d*K
LlxD[$i6cawo,NGznmH~!0?
来自:bbs.fishc.com
Wsaq&d.2!;rG-YBS<RZw@ok
嗯,咱现在还没开始学习任何 C 语言的语法呢,当然是让大家抄啦!!(不抄错也是一件蛮困难的事儿噢,不信你试试看~)g+j(ZGH
aB'hMz,0@sn`pTk!t>6G3K#~{H%OYr
这节课才刚讲 C 语言可移植性高,马上小甲鱼就给自己打脸了!对于目录扫描来说,各个操作系统还真是自成一家……所以请选择你使用的操作系统,抄下代码并编译执行程序。OvF^?
,j_E4"M:B-v}dX=k7uic^nOD{)eC
程序可以成功执行就算过关啦~(记得截图给我看噢^_^)GaPJ,$&c
b1TAuQJ.OBV$h*t,xRq`CHrl%+
Powered by bbs.fishc.com
c2aVJH6.8gntW~]UYN}lZ1O&z7@Kh
Linux 和 MacOS:Powered by bbs.fishc.com
vLX@xDUN|0,[TrFIRl q
  1. #include <stdio.h>
  2. #include <unistd.h>
  3. #include <dirent.h>
  4. #include <string.h>
  5. #include <stdlib.h>
  6. #include <sys/stat.h>

  7. #define MAX 256

  8. long total;

  9. int countLines(const char *filename);
  10. int isCode(const char *filename);
  11. void findAllDirs(const char *path);

  12. int countLines(const char *filename)
  13. {
  14.         FILE *fp;
  15.         int count = 0;
  16.         int temp;

  17.         if ((fp = fopen(filename, "r")) == NULL)
  18.         {
  19.                 fprintf(stderr, "Can not open the file: %s\n", filename);
  20.                 return 0;
  21.         }

  22.         while ((temp = fgetc(fp)) != EOF)
  23.         {
  24.                 if (temp == '\n')
  25.                 {
  26.                         count++;
  27.                 }
  28.         }

  29.         fclose(fp);

  30.         return count;
  31. }

  32. int isCode(const char *filename)
  33. {
  34.         int length;

  35.         length = strlen(filename);
  36.         
  37.         if (!strcmp(filename + (length - 2), ".c"))
  38.         {
  39.                 return 1;
  40.         }
  41.         else
  42.         {
  43.                 return 0;
  44.         }
  45. }

  46. void findAllDirs(const char *path)
  47. {
  48.         DIR *dp;
  49.         struct dirent *entry;
  50.         struct stat statbuf;

  51.         if ((dp = opendir(path)) == NULL)
  52.         {
  53.                 fprintf(stderr, "The path %s is wrong!\n", path);
  54.                 return;
  55.         }

  56.         chdir(path);
  57.         while ((entry = readdir(dp)) != NULL)
  58.         {
  59.                 lstat(entry->d_name, &statbuf);

  60.                 if (!strcmp(".", entry->d_name) || !strcmp("..", entry->d_name))
  61.                         continue;

  62.                 if (S_ISDIR(statbuf.st_mode))
  63.                 {
  64.                         findAllDirs(entry->d_name);
  65.                 }
  66.                 else
  67.                 {
  68.                         if (isCode(entry->d_name))
  69.                         {
  70.                                 total += countLines(entry->d_name);
  71.                         }
  72.                 }
  73.         }

  74.         chdir("..");
  75.         closedir(dp);
  76. }

  77. int main()
  78. {
  79.         char path[MAX] = ".";

  80.         printf("计算中...\n");

  81.         findAllDirs(path);

  82.         printf("目前你总共写了 %ld 行代码!\n\n", total);

  83.         return 0;
  84. }
复制代码

'9+O7)j{kLPd!x~t>FRh"X`w2-
Windows:版权属于:bbs.fishc.com
?}LJuEfWN;$_YMrzB5(2]j

  1. #include <io.h>
  2. #include <direct.h>
  3. #include <stdio.h>
  4. #include <stdlib.h>
  5. #include <string.h>

  6. #define MAX        256

  7. long total;

  8. int countLines(const char *filename);
  9. void findAllCodes(const char *path);
  10. void findALLDirs(const char *path);

  11. int countLines(const char *filename)
  12. {
  13.         FILE *fp;
  14.         int count = 0;
  15.         int temp;
  16.         
  17.         if ((fp = fopen(filename, "r")) == NULL)
  18.         {
  19.                 fprintf(stderr, "Can not open the file:%s\n", filename);
  20.                 return 0;
  21.         }
  22.         
  23.         while ((temp = fgetc(fp)) != EOF)
  24.         {
  25.                 if (temp == '\n')
  26.                 {
  27.                         count++;
  28.                 }
  29.         }
  30.         
  31.         fclose(fp);
  32.         
  33.         return count;
  34. }

  35. void findAllCodes(const char *path)
  36. {
  37.         struct _finddata_t fa;
  38.         long handle;
  39.         char thePath[MAX], target[MAX];
  40.         
  41.         strcpy(thePath, path);
  42.         if((handle = _findfirst(strcat(thePath, "/*.c"), &fa)) != -1L)
  43.         {
  44.                 do
  45.                 {
  46.                         sprintf(target, "%s/%s", path, fa.name);
  47.                         total += countLines(target);
  48.                 }while (_findnext(handle, &fa) == 0);
  49.         }
  50.    
  51.         _findclose(handle);
  52. }

  53. void findALLDirs(const char *path)
  54. {
  55.         struct _finddata_t fa;
  56.         long handle;
  57.         char thePath[MAX];
  58.         
  59.         strcpy(thePath, path);
  60.         if((handle = _findfirst(strcat(thePath, "/*"), &fa)) == -1L)
  61.         {
  62.                 fprintf(stderr, "The path %s is wrong!\n",path);
  63.                 return;
  64.         }
  65.    
  66.         do
  67.         {        
  68.                 if (!strcmp(fa.name, ".") || !strcmp(fa.name, ".."))
  69.                         continue;
  70.                     
  71.                 if( fa.attrib == _A_SUBDIR)
  72.                 {        
  73.                         sprintf(thePath, "%s/%s", path, fa.name);
  74.                         findAllCodes(thePath);
  75.                         findALLDirs(thePath);
  76.                 }
  77.         }while (_findnext(handle, &fa) == 0);
  78.    
  79.         _findclose(handle);   
  80. }

  81. int main()
  82. {
  83.         char path[MAX] = ".";
  84.         
  85.         printf("计算中...\n");
  86.         
  87.         findAllCodes(path);
  88.         findALLDirs(path);
  89.         
  90.         printf("目前你总共写了 %ld 行代码!\n\n", total);
  91.         system("pause");
  92.         
  93.         return 0;
  94. }
复制代码

.xGjw'zqC}p^em5S=tLrF]9
图一时之快先看答案,你将失去一次锻炼的机会!QaLrA5qFM_
u(oI{=C4h8>~-!vfjPn_c739V5,.
请先自己思考和动手,再回复查看参考答案。
4H`C|.[
.r5O]-R^nta~gzhf2{+TQ1o
测试题答案:Powered by bbs.fishc.com
游客,如果您要查看本帖隐藏内容请回复
Powered by bbs.fishc.com

动动手答案:Powered by bbs.fishc.com
游客,如果您要查看本帖隐藏内容请回复
Powered by bbs.fishc.com

点评

我很赞同!: 5.0 不,我坚决不同意楼主的看法!: 5.0
我很赞同!: 5 不,我坚决不同意楼主的看法!: 5
  发表于 2025-2-11 20:13
我很赞同!: 5
  发表于 2024-3-18 17:36

评分

参与人数 29荣誉 +127 鱼币 +95 贡献 +67 收起 理由
moqizhong + 5 -5 + 3
小白1号666 + 5 + 5 + 3
jixiashier + 10 + 10 鱼C有你更精彩^_^
漫星闪 + 1 鱼C有你更精彩^_^
风归de副歌 -1 + 1 鱼C有你更精彩^_^
咦一哈呦呦 + 5 + 5 + 3 鱼C有你更精彩^_^
初心沫白c + 5 + 5 + 3
午后狂睡 + 5 + 1 + 2
知我枯荣 + 5 + 5 + 3
梅友666 + 3

查看全部评分

小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2015-11-17 04:53:24 | 显示全部楼层
在发布我的答案之前,我想说小甲鱼犯了一个小错误,就是你说JAVA是解释性语言。JAVA其实跟C#一样,都是游离于解释型和编译型之间,就是说编程语言不光是编译型和解释型,JAVA和C#两个语言是游离于二者之间的。
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2015-11-17 04:56:21 | 显示全部楼层
cccp 发表于 2015-11-17 04:53
在发布我的答案之前,我想说小甲鱼犯了一个小错误,就是你说JAVA是解释性语言。JAVA其实跟C#一样,都是游离 ...


http://www.cnblogs.com/o-andy-o/archive/2012/04/11/2442109.html这篇文章详细的说明了JAVA语言的原理

点评

我很赞同!: 5.0 不,我坚决不同意楼主的看法!: 2.0
我很赞同!: 5 不,我坚决不同意楼主的看法!: 2
  发表于 2025-2-11 20:14
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2015-11-17 08:17:26 | 显示全部楼层
  1. #include<stdio.h>
  2. int main(void)
  3. {
  4. printf("hello world\n");
  5. return 0;
  6. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2015-11-17 10:56:27 | 显示全部楼层
下载链接点打不开啊
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2015-11-18 20:23:10 | 显示全部楼层
加油 小甲鱼!!!
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2015-11-20 11:40:05 | 显示全部楼层
报到~~!
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2015-11-20 12:51:42 | 显示全部楼层
UP主辛苦啦:)~~~
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2015-11-20 14:02:46 | 显示全部楼层
本帖最后由 wing1995 于 2015-11-20 18:14 编辑

测试题:
0.
计算机的大脑“CPU”,它只懂的二进制的0和1。
1.
CPU只认识二进制的0和1,是“机器语言”,也被称为“机器码”。
2.
编译,引入大量的助记符,由汇编将助记符转化成机器码。
3.
编译型语言转化成汇编语言最后转换成机器语言,然后给CPU执行;因此,编译型语言是直接以机器语言输入到CPU,不需要经过解释器翻译给CPU,实现了跨平台。
4.
可能性很小,主要原因是“格式不同”以及“API不同”。可执行文件在执行之前,操作系统要有一些准备,不同的操作系统准备工作不同,所以可执行文件的格式不同。解决了“格式不同”的问题,操作系统的API不同,一个可执行文件所执行的绝大多数操作都需要交互才能完成。还有一个是“ABI”(应用二进制接口)不同,它属于应用程序与操作系统之间或者其他应用程序的低级接口;ABI不同于API,API定义的是源代码和库之间的接口,因此同样的代码可以在支持这个库的任何系统中执行,而ABI只允许编译好的木匾代码在使用兼容ABI的系统中无需改动就能执行,然而现在的aBI并没有一个统一的标准。以上三个原因是造成C语言编译的可执行程序不能再windows上面执行,不然的话那么多软件就不需要分不同系统上的安装文件不同了,QQ也可以直接在linux上安装了(haha,开玩笑的)。
5.
解释型语言转换成中间代码,然后发送给解释器,由解释器“翻译”给CPU,这样不同的平台只要有解释器就好了~
6.
“查表”,将莫斯密码对着“莫斯密码编码表”解密成明文,就是解码的过程;关键是那个表。然而,很多时候,明文都是被进一步被加密了的,因此要想完全了解对方的心思还是需要及其密集的心思。
7.
亲们趁敌人吃饭时发动进攻

测试题,结果竟然是酱紫~
捕获.JPG
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2015-11-20 14:40:43 | 显示全部楼层
为什么我的总共写了0行代码

0.jpg
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2015-11-20 23:21:01 | 显示全部楼层
kkkkkkkkkkkkkkkk
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2015-11-21 13:25:47 | 显示全部楼层
:lol:不知道怎么贴图片
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2015-11-21 19:07:09 | 显示全部楼层
0.计算机只认别二进制码
1.机器语言
2.编译
3.编译形语言运行的程序是二进制文件,只要编译一次,速度快,解释型语言每次运行都要运行几次
4.大部分可以,但少部分需要改动
5.因为解释形语言靠解释器编译,不需要考虑硬件
6.每个长度的长音和短音都对应一个字母,就组成了句子
7.亲们成敌人吃饭时发动进攻

小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2015-11-21 23:16:36 | 显示全部楼层
0、他只知道0和1
1、机器语言
2、编译
3、编译型,编译成机器语言后让CPU直行。解释型,将语言转换成中间代码,再由解释器将中间代码一句一句解释给CPU直行
4、不能
5、他是将源代码转换成中间代码,在用解释器解释中间代码
6、QINMEN
CHEND
IRENC
HIFAN
SHIF
ADONG
JINGO
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2015-11-22 00:35:47 | 显示全部楼层
为啥我用vc提示找不到dir.h文件。用dev++就OK呢?
20151122003732.png
20151122003559.jpg
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2015-11-22 07:44:19 | 显示全部楼层
我要看
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2015-11-22 08:07:12 | 显示全部楼层
let me see see
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2015-11-22 08:31:27 | 显示全部楼层
  1. #include <Iostream>
  2. #include <Windows.h>
  3. #include <DbgHelp.h>
  4. #pragma  comment(lib,"DbgHelp")

  5. int total = 0;
  6. int getcount( char*  m_filename )
  7. {
  8.         HANDLE hFile;
  9.         hFile = CreateFileA( m_filename, GENERIC_READ, NULL, NULL, OPEN_EXISTING, FILE_ATTRIBUTE_NORMAL, NULL );
  10.         if ( INVALID_HANDLE_VALUE == hFile )
  11.         {
  12.                 return(0);
  13.         }

  14.         DWORD dwSizes;
  15.         dwSizes = GetFileSize( hFile, NULL );

  16.         /* 分配缓冲区 */
  17.         char *cBuf = new char[dwSizes + 1];
  18.         cBuf[dwSizes] = 0;

  19.         /* 读入文件 */
  20.         DWORD NumberOfBytesRead;
  21.         ReadFile( hFile, (LPVOID) cBuf, dwSizes, &NumberOfBytesRead, NULL );
  22.         if ( dwSizes != NumberOfBytesRead )
  23.         {
  24.                 return(0);
  25.         }

  26.         int ncount = 0;
  27.         for ( int i = 0; i < dwSizes; i++ )
  28.         {
  29.                 if ( 0 == strncmp( cBuf + i, "\r\n", 2 ) )
  30.                 {
  31.                         /*有一行 */
  32.                         ncount++;
  33.                 }
  34.         }


  35.         delete[]cBuf;
  36.         CloseHandle( hFile );
  37.         return(ncount + 1);
  38. }


  39. BOOL CALLBACK EnumDirTreeProc(
  40.         _In_ CHAR*   FilePath,
  41.         _In_opt_ PVOID CallerData
  42.         )
  43. {
  44.         int m_ncount = getcount( FilePath );
  45.         std::cout << FilePath << m_ncount << std::endl;

  46.         total += m_ncount;
  47.         return(FALSE);
  48. }


  49. int main( void )
  50. {
  51.         /* 获取当前目录路径 */
  52.         CHAR currentDir[MAX_PATH];

  53.         GetCurrentDirectoryA( MAX_PATH, currentDir );

  54.         EnumDirTree( NULL, currentDir, "*.C", NULL, (PENUMDIRTREE_CALLBACK) EnumDirTreeProc, NULL );

  55.         std::cout << std::endl << "Total lines:" << total;

  56.         system( "Pause" );

  57.         return(0);
  58. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2015-11-22 08:33:57 | 显示全部楼层
递归那太慢了。。。。。
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2015-11-22 19:35:38 | 显示全部楼层
看看答案,:smile
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-6-4 14:59

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表