C语言的第二次实验报告
一、思路及方法
11-8 螺旋方阵
设计二维数组,通过对方阵的行和列进行特征分析找出其中规律,利用循环即可将方阵输出。
12-6 字符串转换成十进制整数
设计字符数组,用getchar函数逐个截取,并设定以#为结束符;将每个符合条件的数组元素,利用ASCII码的十进制关系进行变化并输出。
13-5 判断回文字符串
设计字符型数组,并利用指针来传递输入内容;通过函数来判断是否为回文。
14-6 通讯录的录入与显示
通过定义结构数组,通过循环输入和输出存储内容。
15-10 建立学生信息链表
设计动态链表,对每项内容分别进行判断和处理。
二、部分源程序
11-8 螺旋方阵
for(i=;i<m;i++){
for(j=i;j<n-i;j++){
a[i][j]=N;
N++;
}
for(j=i+;j<n-i;j++){
a[j][n-i-]=N;
N++;
}
for(j=n-i-;j>=i;j--){
a[n-i-][j]=N;
N++;
}
for(j=n--i;j>=i+;j--){
a[j][i]=N;
N++;
}
}
for(i=;i<n;i++){
for(j=;j<n;j++)
printf("%3d",a[i][j]);
printf("\n");
}
12-6 字符串转换成十进制整数
while((str[i]=getchar())!='#')
i++;
for(j=0;j<=i;j++){
if(str[j]=='-'){
k=j;
break;
}
}
for(j=0;j<=i;j++){
if((str[j]<='9'&&str[j]>='0')||(str[j]<='F'&&str[j]>='A')||(str[j]<='f'&&str[j]>='a')){
a=j;
break;
}
}
b=k;
k=0;
for(j=0;str[j]!='\0';j++){
if((str[j]<='9'&&str[j]>='0')||(str[j]<='F'&&str[j]>='A')||(str[j]<='f'&&str[j]>='a')){
c[k]=str[j];
k++;
}
}
c[k]='\0';
int number=0;
for(i=0;c[i]!='\0';i++){
if(c[i]>='0'&&c[i]<='9')
number=number*16+c[i]-'0';
else if(c[i]>='a'&&c[i]<='f')
number=number*16+c[i]-'a'+10;
else if(c[i]>='A'&&c[i]<='F')
number=number*16+c[i]-'A'+10;
}
13-5 判断回文字符串
bool palindrome( char *s )
{
int i=0,n,m;
n=strlen(s);
if(n%2==0){
m=n/2;
for(i=0;i<=m;i++){
if(s[i]!=s[n-1-i]){
return false;
}
}
return true;
}
else{
m=n/2+1;
for(i=0;i<=m;i++){
if(s[i]!=s[n-1-i]){
return false;
}
}
return true;
}
}
14-6 通讯录的录入与显示
#include<stdio.h>
struct message {
char name[100];
char birth[100];
char sex;
char number[100],phone[100];
};
int main()
{
int N,n;
scanf("%d",&N);
struct message s[11];
int i,j,k;
for(i=0;i<N;i++)
scanf("%s %s %c %s %s",&s[i].name,&s[i].birth,&s[i].sex,&s[i].number,&s[i].phone); scanf("%d",&n);
for(i=0;i<n;i++){
scanf("%d",&k);
if(k<N&&k>=0){
printf("%s %s %s %c %s\n",s[k].name,s[k].number,s[k].phone,s[k].sex,s[k].birth);
}
else
printf("Not Found\n");
}
return 0;
}
15-10 建立学生信息链表
void input()
{
int num,score;
char name[20];
struct stud_node *p;
scanf("%d",&num);
while(num){
p=(struct stud_node *)malloc(sizeof(struct stud_node));
scanf("%s %d",name,&score);
p->num=num;
p->score=score;
strcpy(p->name,name);
if(head==NULL)
head=p;
else
tail->next=p;
tail=p;
scanf("%d",&num);
}
}
三、心得体会
1.在创建链表时一定要注意对每个链表进行空间的分配,核对链表最后一个的NEXT是否指向NULL。
2.定义嵌套结构时一定要注意能否正确的表示嵌套起来的结构内的部分。
3.在用利用自定义函数的功能时指针可以避免返回值的书写。
4.灵活运用ASCII码和getchar();注意%c会“吃”空格。
5灵活分析目标要求的特征,可以通过特点进行总结,使函数作用域扩大。
C语言的第二次实验报告的更多相关文章
- 20145330《Java程序设计》第二次实验报告
20145330<Java程序设计>第二次实验报告 实验二 Java面向对象程序设计 实验内容 1.初步掌握单元测试和TDD 2.理解并掌握面向对象三要素:封装.继承多态 3.初步掌握UM ...
- 20145320《Java程序设计》第二次实验报告
20145320<Java程序设计>第二次实验报告 北京电子科技学院(BESTI)实验报告 课程:Java程序设计 班级:1453 指导教师:娄嘉鹏 实验日期:2016.04.12 15: ...
- 《Java程序设计》第二次实验报告
20145220 <Java程序设计>第二次实验报告 课程:Java程序设计 指导教师:娄嘉鹏 实验日期:2016.04.12 实验名称:Java面向对象程序设计 实验内容 初步掌握单元测 ...
- 20145333 《Java程序设计》第二次实验报告
2014333 <Java程序设计>第二次实验报告 课程:Java程序设计 指导教师:娄嘉鹏 实验日期:2016.04.12 实验名称:Java面向对象程序设计 实验内容 初步掌握单元测试 ...
- 20145240 《Java程序设计》第二次实验报告
20145240 <Java程序设计>第二次实验报告 北京电子科技学院(BESTI)实验报告 课程:Java程序设计 班级:1452 指导教师:娄嘉鹏 实验日期:2016.04.12 实验 ...
- java程序设计第二次实验报告
北京电子科技学院(BESTI) 实验报告 课程:数据结构 班级:1352 姓名:何伟钦 学号:20135223 成绩: 指导教师:娄嘉鹏 实验日期: ...
- java第二次实验报告20135231
Java实验报告二:Java面向对象程序设计 20135231 何佳 实验要求: 1. 初步掌握单元测试和TDD 2. 理解并掌握面向对象三要素:封装.继承.多态 3. 初步掌握UML建模 4. 熟悉 ...
- 2019JAVA第二次实验报告
Java实验报告 班级 计算机科学与技术二班 学号 20188442 姓名 吴怡君 完成时间 2019/9/19 评分等级 实验二 Java简单类与对象 实验目的 掌握类的定义,熟悉属性.构造函数.方 ...
- 第二次实验报告:使用 Packet Tracer 分析应用层协议
个人信息: 姓名:倪晓东 班级:计算1811 学号:201821121020 1 实验目的 熟练使用Packet Tracer工具.分析抓到的应用层协议数据包,深入理解应用层协议,包括语法.语义.时序 ...
随机推荐
- CentOS7.2 安装zookeeper3.4.9
Zookeeper-3.4.9 下载Zookeeper-3.4.9 在/usr/local下创建hadoop文件夹 将下载的文件迁移到该文件夹下,并解压 tar -zxvf zookeeper-3.4 ...
- POJ2533_Longest Ordered Subsequence (线性动态规划变形)
本题求一个字符串中的最长递增子序列的长度. 动态规划方程 a[]记录字符串: d[i]记录以第i个元素为最后一个元素的最长递增序列的长度 则 d[i+1]=1+max(d[j]) 其中(j<i ...
- When should I use OWIN Katana?
When should I use OWIN Katana? 解答1 In asp.net WebApi v2, the OWIN pipeline becomes the default. It i ...
- Ubuntu 安装Docker
参考:官网 安装依赖包: $ sudo apt-get update $ sudo apt-get install -y --no-install-recommends \ linux-image-e ...
- BZOJ 2876 【NOI2012】 骑行川藏
题目链接:骑行川藏 听说这道题需要一些高数知识 于是膜了一发dalao的题解……然后就没了…… 不要吐槽我的精度TAT……eps设太小了就TLE,大了就Wa……我二分的边界是对着数据卡的…… 下面贴代 ...
- 总结关于express vue-cli
零零散散,拼起来,花了不少时间,这回把一些东西拼一下吧,免得到时又得重头开始,Blog还没弄好,打算用这些重新写一个,稍接不上,就落后了,这是技术,技术是不断更新换代的,明天这个框架,可以后天就有一个 ...
- python 判断两个列表是否有公共元素
def common_data(list1, list2): result = False for x in list1: for y in list2: if x == y: result = Tr ...
- Spring IOC容器的初始化流程
IOC初始化流程 Resource定位:指对BeanDefinition的资源定位过程.Bean 可能定义在XML中,或者是一个注解,或者是其他形式.这些都被用Resource来定位, 读取Resou ...
- Java Spring-AOP中的动态代理
2017-11-10 16:17:12 AOP中有两种代理方式,分别是JDK的动态代理和CGLib的动态代理. JDK的动态代理 Proxy 提供用于创建动态代理类和实例的静态方法,它还是由这些方法创 ...
- 个人知识管理系统Version1.0开发记录(04)
demo model 我们采用mvc软件架构模式,方便以后用Struts2框架技术优化.重构.封装.这次主要设计一些常用的方法工具,即数据访问逻辑.工具:eclipse.oracle.sqldevel ...