当前位置:首页 » 存储配置 » c存储坐标

c存储坐标

发布时间: 2024-09-05 03:01:36

⑴ 设计一个散列函数,用它存储二维点的坐标。这是我们的c语言编程作业,我写了如下代码,但是有BUG:

这个已经帮你改了,你可以运行一下
# include <stdio.h>
# include <malloc.h>
# include <string.h>
#define NHASH 31

typedef struct zuobiao
{
int x;
int y;
struct zuobiao * next; //chain
}Nameval;

//函数声明
Nameval * create();

Nameval *srt(Nameval *head,Nameval *t);

void main(void)
{

Nameval * sym,*head;
head=create();
//print(head);
sym=(struct zuobiao*)malloc(sizeof(struct zuobiao));
printf("请输入要查找的坐标值:\nx = ");
scanf("%d", &sym->x);
printf("y = "); scanf("%d", &sym->y);
srt(head,sym);

}
///////////////////////////////////////////////////////////////
Nameval * create()
{
Nameval *head,*tail,*p;int x;
head= tail=NULL;
printf("请输入坐标点的个数:");
scanf("%d",&x);
while(x>0)
{
p=(struct zuobiao*)malloc(sizeof(struct zuobiao));
printf("请输入坐标的值:\nx = ");
scanf("%d", &p->x);
printf("y = "); scanf("%d", &p->y);

//p->age=x;
p->next=NULL;
if(head==NULL)
{
head=tail=p;
}
else
{
tail->next=p;
tail=p;
}
x--;
}

return(head);
}

//////////////////////////////////////////////////////////////////

Nameval *srt(Nameval *head,Nameval *t)
{
Nameval *p,*q;
p=(Nameval *)malloc(sizeof(Nameval));
p=head;
if(p==NULL) return NULL;
while(((p->x!=t->x)||(p->y!=t->y))&&(p->next!=NULL))
{
q=p;
p=p->next;
}
if((p->x==t->x)&&(p->y==t->y))
{
printf("已经有了这个坐标\n");
}
else if((p->next==NULL)&&(p->x!=t->x))
{

p->next=t;
t->next=NULL;
printf("新坐标已经插入\n");

}
//free(p);
return head;
}
可以推荐你加QQ群218691837

⑵ c语言中若要输入坐标应该怎么办

先算出纵坐标的值,然后
用二维数组来存储坐标,如:int a[5][5]; 可以用a[0][0] a[0][1]....
a[i][j]....a[4][3] a[4][4],来存储5对坐标值,i、j分别是横坐标和纵坐标。

热点内容
如何用命令提示符改密码无需密码 发布:2025-08-16 10:23:46 浏览:954
aov国际版是什么服务器 发布:2025-08-16 10:14:38 浏览:397
攀升编程 发布:2025-08-16 10:13:14 浏览:483
加工中心刻字编程 发布:2025-08-16 09:59:43 浏览:100
安卓手机屏幕最好的是什么手机 发布:2025-08-16 09:40:10 浏览:395
python基础pdf下载 发布:2025-08-16 09:38:25 浏览:591
矩阵详细编程 发布:2025-08-16 09:28:39 浏览:952
跨境电商平台服务器是什么 发布:2025-08-16 09:23:42 浏览:946
android推送广告 发布:2025-08-16 09:13:04 浏览:181
怎么下载安卓系统软件 发布:2025-08-16 09:11:26 浏览:768