单号
答案
1
#include <stdio.h>
#include <unistd.h>
#include <dirent.h>
#include <string.h>
#include <stdlib.h>
#include <sys/stat.h>
#define MAX 256
long total;
int countLines(const char *filename);
int isCode(const char *filename);
void findAllDirs(const char *path);
int countLines(const char *filename)
{
FILE *fp;
int count = 0;
int temp;
if ((fp = fopen(filename,"r")) == NULL)
{
fprintf(stderr,"Can not open the file:%\n",filename);
return 0 ;
}
while ((temp = fgetc(fp)) != EOF)
{
if (temp == '\n')
{
count++;
}
}
fclose(fp);
return count;
}
int isCode(const char *filename)
{
int length
length = strlen(filename);
if (!strcmp(filename + (length - 2),".c"))
{
return 1;
}
else
{
return 0;
}
}
void findAllDirs(const char *path)
{
DIR *dp
struct dirent *entry;
struct stat statbuf;
if ((dp = opendir(path)) == NULL)
{
fprintf(stderr,"The path %s is wrong!\n",path);
return;
}
chdir(path);
while ((entry = readdir(dp)) ! = NULL)
{
lstat(entry->d_name,&statbuf);
if (!strcmp(".",entry->d_name) || !strcmp("..", entry->d_name))
continue;
if (S_ISDIR(statbuf.st_mode))
{
findAllDirs(entry->d_name);
}
else
{
if(isCode(entry->d_name))
{
total += countLines(entry->d_name);
}
}
}
chdir("..");
closedir(dp);
}
int main()
{
char path = ".";
printf("计算中...\n");
findAllDirs(path);
printf("目前你总共写了 %ld 行代码!\n\n", total);
return 0;
}
1
额
1.机器语言
2.编译
3.解释型语言需要解释器,不产生目标代码;编译型语言要产生目标代码
4.是
{:5_106:}
考研复试过来看看
0.1.2.3.4.5.67
看看答案
{:5_96:}
学到了
1
修改
+3
0.因为计算机是运用二进制代码运行程序的,只认识0和1
1.机器语言
2.编译
3.编译型语言将源代码编译成可执行文件,之后再运行代码时只需运行可执行文件即可,而解释性语言则是编译一行代码就运行一行,并不会产生可执行文件,因此每次运行都需要进行编译。
4.能
5.
6.运用ASCII码进行的字符转换
7.
11
冲冲冲
哎,没成功