一、思路及方法

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语言的第二次实验报告的更多相关文章

  1. 20145330《Java程序设计》第二次实验报告

    20145330<Java程序设计>第二次实验报告 实验二 Java面向对象程序设计 实验内容 1.初步掌握单元测试和TDD 2.理解并掌握面向对象三要素:封装.继承多态 3.初步掌握UM ...

  2. 20145320《Java程序设计》第二次实验报告

    20145320<Java程序设计>第二次实验报告 北京电子科技学院(BESTI)实验报告 课程:Java程序设计 班级:1453 指导教师:娄嘉鹏 实验日期:2016.04.12 15: ...

  3. 《Java程序设计》第二次实验报告

    20145220 <Java程序设计>第二次实验报告 课程:Java程序设计 指导教师:娄嘉鹏 实验日期:2016.04.12 实验名称:Java面向对象程序设计 实验内容 初步掌握单元测 ...

  4. 20145333 《Java程序设计》第二次实验报告

    2014333 <Java程序设计>第二次实验报告 课程:Java程序设计 指导教师:娄嘉鹏 实验日期:2016.04.12 实验名称:Java面向对象程序设计 实验内容 初步掌握单元测试 ...

  5. 20145240 《Java程序设计》第二次实验报告

    20145240 <Java程序设计>第二次实验报告 北京电子科技学院(BESTI)实验报告 课程:Java程序设计 班级:1452 指导教师:娄嘉鹏 实验日期:2016.04.12 实验 ...

  6. java程序设计第二次实验报告

    北京电子科技学院(BESTI) 实验报告 课程:数据结构    班级:1352    姓名:何伟钦     学号:20135223 成绩:            指导教师:娄嘉鹏      实验日期: ...

  7. java第二次实验报告20135231

    Java实验报告二:Java面向对象程序设计 20135231 何佳 实验要求: 1. 初步掌握单元测试和TDD 2. 理解并掌握面向对象三要素:封装.继承.多态 3. 初步掌握UML建模 4. 熟悉 ...

  8. 2019JAVA第二次实验报告

    Java实验报告 班级 计算机科学与技术二班 学号 20188442 姓名 吴怡君 完成时间 2019/9/19 评分等级 实验二 Java简单类与对象 实验目的 掌握类的定义,熟悉属性.构造函数.方 ...

  9. 第二次实验报告:使用 Packet Tracer 分析应用层协议

    个人信息: 姓名:倪晓东 班级:计算1811 学号:201821121020 1 实验目的 熟练使用Packet Tracer工具.分析抓到的应用层协议数据包,深入理解应用层协议,包括语法.语义.时序 ...

随机推荐

  1. RC522 模块驱动程序

    本文主要讲述了基于SPI总线的RC522驱动程序的设计.描述了主控如何与从设备通过SPI总线进行数据的读写. 一 在SPI驱动中,有两个重要的结构:spi_device&spi_driver. ...

  2. HDU 3605 Escape(状态压缩+最大流)

    http://acm.hdu.edu.cn/showproblem.php?pid=3605 题意: 有n个人和m个星球,每个人可以去某些星球和不可以去某些星球,并且每个星球有最大居住人数,判断是否所 ...

  3. codeforces 354 div2 C Vasya and String 前缀和

    C. Vasya and String time limit per test 1 second memory limit per test 256 megabytes input standard ...

  4. 使用CAS实现无锁的SkipList

    无锁 并发环境下最常用的同步手段是互斥锁和读写锁,例如pthread_mutex和pthread_readwrite_lock,常用的范式为: void ConcurrencyOperation() ...

  5. python 将类属性转为字典

    class dictObj(object): def __init__(self): self.x = 'red' self.y = 'Yellow' self.z = 'Green' def do_ ...

  6. postgresql中终止正在执行的SQL语句

    在Linux系统中可以使用kill [pid]的方式强制删除进程,但对于修改数据表的语句来说,这样可能导致postgresql进入recovery mode,这样会导致锁表. Postgresql的运 ...

  7. 读underscore

    最近在拜读只有1700行(含注释)代码的Underscore.js 1.9.1,记录一些东西 (参考https://underscorejs.org/underscore.js,https://git ...

  8. git add 的一点说明

    git add --cached 这里 --cached是什么意思呢?要解释清楚这个问题,我们必须先了解一个文件在git中的状态. [commit]----[stage]-----[checkout] ...

  9. MVVM特点、源(数据)与目标(如:控件等)的映射

    数据(源,viewMode表示)与控件(目标)的完全映射, 在绑定之后,通过操作数据,改变控件显示效果.显示内容.状态等.

  10. c#只读字段和常量的区别,以及静态构造函数的使用 .

    using System;using System.Collections.Generic;using System.Linq;using System.Text; namespace Console ...