第二章:SCP-087第【数据删除】次探索

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了第二章:SCP-087第【数据删除】次探索相关的知识,希望对你有一定的参考价值。

参考技术A 皮特呆在房间里一动不动,突然保安请皮特出来,让他尝试试验SCP-087,成了第five次探索(由于机密,题目中标着数据删除)。

资料:(四级以下人员严禁观看,否则将会被消除记忆)

load博士:知道你的任务了吧?

皮特:懂得。

load博士:请继续。

皮特走了几步到第3层,听到了孩子的哭声,放了个LED灯到墙壁上。然后走到了第10层,从耳机里听见了皮特害怕而越来越快的喘气声。

皮特:我tm不想继续了!

load博士:不行,你现在没理由申请返回。

皮特又走了23多步,现在到了第19层。

皮特:这是什么?

load博士:这是······

这是第一次探索留下的营养品,为了探索,load博士没告诉皮特真相。

皮特:这好黑啊······啊!

load博士:怎么了?

皮特:这有突出来的石头!差点绊倒我!!

load博士:请继续,遇到环境变化和SCP-087-1再停下。

皮特又走到了32层,吃了一个营养品,又走到了38层。

皮特:血迹!

load博士:这是第一次探索留下的血迹,请继续。

皮特:怎么那么多血迹,还没有血腥味儿!

load博士:第◼次探索就出现了,这为正常事件,不影响探索,请继续。

皮特又走到了第52层,喝了19毫升的水,继续出发,又走到了第63层,任然没有SCP-087-1的痕迹。

皮特:这是楼梯吗,走了好多层,都没到!

load博士:上一次探索都走到600多层了,继续,你目前没理由回来。

皮特:啊呀!

load博士:怎么了,大惊小怪的

皮特:有一道墙破裂了,裂缝16厘米长!

load博士:这是SCP-087的怪事,请继续。

皮特又走到了第89层,感觉越来越暗了,关闭探照灯,像失明一样。皮特又走到了129层,遇到了SCP-087-1。

皮特:啊啊啊,这······是【喘气】什么?!

load博士:这是SCP-087-1,它【被切断】,上几次探索也遇到了。

皮特:TM的这东西是什么,你是谁呀!啊!!

皮特逃到了第92层,SCP-087-1消失了。

皮特:吓死我了!

load博士:你的背包里有手枪,遇到SCP-087-1的时候可以用。请继续。

皮特一声没出,又走到了第139层,喝了13毫升的水,继续出发到第153层。

皮特:黑死了,越来越暗,为什么非要我尝试试验这个破SCP?!

load博士:不许反悔,你走到第300层回来。

皮特:好吧······这是什么?

皮特:我发现一张广告,语言······看不懂,皱巴巴的!

load博士:干得好D-9921,你可以继续了,遇到环境变化再停。

皮特走到第298层,预测再走2层就可以往回走了,走到了第300层,遇到了SCP-087-1.

皮特:你怎么又来了?!【喘气】我【数据删除】······

load博士:冷静,你可以后退了。

皮特:好!【喘气】天哪!!!

皮特走到了第231层,看见SCP-087-1就在身后,拿起枪开了一枪。

皮特:怎么打不死,你是人吗?!

load博士:冷静,后退,再坚持······

皮特虽然没听博士的回应,但坚持走到了第27层,看见一个洞,这个洞在墙上,刚才也没有,皮特看见里面有SCP-087-2诡异笑脸。

皮特:啊啊啊啊,这是什么鬼!刚遇到怪人,在这又遇到了一张恐怖的笑脸,你又是谁啊!【喘气】

皮特再次往上跑,跑到第一层,坐在通往SCP-087的入口,在设备里听到了皮特的碎裂声,10分钟后,碎裂声停止。

【采访结束】

皮特在这次探索结束后,突然要求让博士清除自己关于SCP-087的记忆,但由于被拒绝,皮特形成了幽团恐怖症,黑暗恐怖症。

第二次作业

作业要求一:
作业截图:
C高级第二次作业(1)
6-7:

6-8:

6-9:

7-1:

C高级第二次作业(2):
7-1:

7-2:

C高级第二次作业(3):
6-1:

6-2:

作业要求二:
6-7 删除字符串中数字字符
1.实验代码:

#include <stdio.h>
void delnum(char *s);
int main ()
{ char item[80];
gets(item);
 delnum(item);
 printf("%s\\n",item);
 return 0;
}
void delnum(char *s)
{
  int i=0,j=0;
  while(s[i]!=\'\\0\'){
    if(s[i]>\'9\'||s[i]<\'0\')
    {
      s[j]=s[i];
      j++;
    }
    i++;
  }
  s[j]=\'\\0\';
}

2.设计思路:
第一步:本题要删除字符串中数字,通过数组遍历字符串,遇到数字删除,将之后的字符向前移动。
第二步:定义变量ij,运用if判断字符串是否为数字,循环遍历字符串和ASCII码值达到目的。
3.遇到问题:在运用while循环时出现编译错误,通过devc++提示改正
4.流程图:

6-8统计子串在母串出现的次数
1.实验代码:

#include<stdio.h>
int fun(char *str,char *substr);
int main()
{ char str[81]="asdasasdfgasdaszx67asdmklo",substr[4]="asd";
 int n;
 n=fun(str,substr);
 printf("n=%d\\n",n);
 return 0;
}
int fun(char *str,char *substr)
{
    int i=0,num=0;
  
    do
	{
        if(*(str+i)==\'a\'&&*(str+i+1)==\'s\'&&*(str+i+2)==\'d\')
		{
            num++;
        }
        i++;
	}while(*(str+i)!=\'\\0\');
    return num;
} 

2.设计思路:
第一步:运用if语句和循环来遍历字符串和判断字符串是否为子串;
第二步:遇到子串循环变量加一,循环至末尾输出。
3.遇到问题:
提交过程中遇到了很多次编译错误,通过devc++提示改正。
几次答案错误是因为把I++放错了位置,仔细检查改正过来。

6-9字符串中除首尾字符外的其余字符按降序排列
1.实验代码:

#include <stdio.h>
int fun(char *s,int num);
int main()
{
 char s[10];
 gets(s);
 fun(s,7);
 printf("%s",s);
 return 0;
 }
int fun(char *s,int num)
{
    int i,j;
    char temp;
    for(i=0;i<num;i++)
    {
       for(j=1;j<num-2;j++)
       {
        if(s[j]<s[j+1])
       {
	   temp=s[j]; 
	   s[j]=s[j+1]; 
	   s[j+1]=temp;
	   }
}
}
}

2.设计思路:
第一步:定义循环变量,运用循环遍历数组。
第二步:运用冒泡法进行排序。
3.遇到问题:没有遇到问题。

7-1输出学生成绩
1.实验代码:

#include<stdio.h> 
int main()
{
int n,i;
float max,min=100,sum=0,x,average;
scanf("%d",&n);
for(i=1;i<=n;i++)
{
	scanf("%f ",&x);
	if(x>max)
	{
		max=x;
	}
	if(x<min)
	{
		min=x;
	}
	sum=sum+x;
	average=sum/n;
}
printf("average = %.2f\\n",average);
printf("max = %.2f\\n",max);
printf("min = %.2f",min);
return 0;
}

2.设计思路:这道题运用了常规的思路,并没有想到如何运用指针。
第一步:定义出各个变量。
第二步:运用if语句和计算输出想要结果。
3.遇到问题:这道题在提交的过程中也遇到了很多次错误,总的来说都是不够认真所导致。仔细检查后改正。

7-1计算职工工资
1.实验代码:

#include<stdio.h>
struct employees 
{                                      
    char name[10];                 
    float basic,floating,out;
}; 
int main()
{
    int n,i=0;
    scanf("%d",&n);
	struct employees e[n];
	for(i=0;i<n;i++)
	{
        scanf("%s %f %f %f",e[i].name,&e[i].basic,&e[i].floating,&e[i].out);
    }
    for(i=0;i<n;i++)
    {
        printf("%s %.2f\\n",e[i].name,e[i].basic+e[i].floating-e[i].out);
    }
}

2.设计思路:
第一步:定义一个结构体,其中含有名字,基本工资,浮动工资和支出。
第二步;在函数中输入一个n,n为人数,运用循环输入各员工的数据,并输出结果。
3.遇到问题:对于代码的检查不够仔细导致总是答案错误,最后发现输出结果中的e[i]错写为e[n]。
4.流程图:

7-2计算平均成绩
1.实验代码:

#include<stdio.h>
#include<stdlib.h>
struct student
{
	char name[10];
	char num[5];
	int score;
};
int main()
{
	int n,i=0;
	float average,sum=0;
	scanf("%d",&n);
	struct student s[n];
	for(i=0;i<n;i++){
		scanf("%s %s %d",s[i].num,s[i].name,&s[i].score);
		sum=sum+s[i].score;
	}
	average=(float)(sum/n*1.0);
	printf("%.2f\\n",average);
	for(i=0;i<n;i++)
	{
		if((float)(s[i].score)<average)
		{
			printf("%s %s\\n",s[i].name,s[i].num);
		}
	}
}

2.设计思路:
第一步:依然是定义一个结构体,其中有姓名 学号和成绩;
第二步:在函数中定义出n,i,sum,average,各值;
第三步;运用循环输入数据,运用算法计算结果,再次用循环输出值;
3.遇到问题:没有遇到问题

6-1 按等级统计学生成绩
1.实验代码:

#include <stdio.h>
#define MAXN 10

struct student{
    int num;
    char name[20];
    int score;
    char grade;
};

int set_grade( struct student *p, int n );

int main()
{   
    struct student stu[MAXN], *ptr;
    int n, i, count;
    ptr = stu;
    scanf("%d\\n", &n);
    for(i = 0; i < n; i++){
       scanf("%d%s%d", &stu[i].num, stu[i].name, &stu[i].score);
    } 
   count = set_grade(ptr, n);
   printf("The count for failed (<60): %d\\n", count);
   printf("The grades:\\n"); 
   for(i = 0; i < n; i++)
       printf("%d %s %c\\n", stu[i].num, stu[i].name, stu[i].grade);
    return 0;
}
int set_grade( struct student *p, int n )
{
    int i, count = 0;
    for(i = 0;i < n;i ++,p++){
        if((*p).score <=100 && (*p).score >= 85){
            (*p).grade = \'A\';
        }else if((*p).score <85 && (*p).score >= 70){
            (*p).grade = \'B\';
        }else if((*p).score && (*p).score >= 60){
            (*p).grade = \'C\';
        }else{
            (*p).grade = \'D\'; 
            count ++;
        }
    }
    return count;
 } 

2.设计思路:
第一步:定义变量i和count.
第二步:通过循环和if语句判断学生成绩,最后返还count值;
3.遇到问题:没有遇到问题。

6-2结构体数组按总分排序
1.实验代码:

#include <stdio.h>
struct student					
{
int num;
char name[15];
float score[3];
float sum;
};
void calc(struct student *p,int n);	 
void sort(struct student *p,int n);
int main()
{
struct student stu[5];
int i,j;
float f;
for(i=0;i<5;i++)
{
	scanf("%d%s",&stu[i].num,stu[i].name);
	for(j=0;j<3;j++)
	{ 
    	scanf("%f",&f);
		stu[i].score[j]=f;
	}
}
calc(stu,5);
sort(stu,5);
for(i=0;i<5;i++)
{
	printf("%5d%15s",stu[i].num,stu[i].name);
	printf("  %.1f  %.1f  %.1f  %.1f\\n",stu[i].score[0],stu[i].score[1],stu[i].score[2], stu[i].sum);
}
return 0;
}
void calc(struct student *p,int n)
{
	int i=0;
	for(i=0;i<n;i++){
		p[i].sum=p[i].score[0]+p[i].score[1]+p[i].score[2];
	}
}	 
void sort(struct student *p,int n)
{
	int j=0,i=0;
	struct student a;
	for(i=0;i<n-1;i++)
	{
		for(j=0;j<n-1-i;j++)
		{
			if(p[j].sum<p[j+1].sum)
			{
				a=p[j];
				p[j]=p[j+1];
				p[j+1]=a;
			}
		}
	}
}

2.设计思路:起初并没有设计思路,而后还是求助于大佬赵寅胜。
第一步:在void calc这一函数中求出各同学成绩和;
第二步:在void sort函数中用冒泡法将结果排序;
3.遇到问题:在编程过程中遇到了很多问题,比较突出的就是编译错误,这是结构指针没有熟练掌握所导致的。最后还是赵寅胜大佬指出我的指针错误运用。
4.流程图:

作业要求三:
上传至git
地址: https://coding.net/u/AssassinCreed/p/Devil-May-Cry/git/tree/master/?public=true
截图:

作业要求四
表格:

折线图:

作业要求五:
评论同学:
顾家玮:http://www.cnblogs.com/qq807443119/p/8747414.html
班庆泽:http://www.cnblogs.com/wsbqz/p/8746704.html
高立彬:http://www.cnblogs.com/gao628526/p/8665187.html

以上是关于第二章:SCP-087第【数据删除】次探索的主要内容,如果未能解决你的问题,请参考以下文章

如何使用 Unix 从一行中删除第二次出现

sqlite3 没有第二次打开预填充的数据库

断言失败第二次添加/删除

从对象数组中删除第二次出现的对象[重复]

C高级第二次作业

php 安装过程 第二次探索