【ACM】杭电OJ 2019

可以用链表写,也可以用顺序表写:

下面是链表的AC代码:

#include <stdio.h>
#include <stdlib.h>
typedef struct node
{
	int info;
	struct node* next;
}N;
N* init()
{
	return NULL;
}
N* creat(N* head,int n)
{
	int i,x;
	N *p, *q = NULL;
	for (i = 1; i <= n; i++)
	{
		scanf_s("%d", &x);
		p = (N*)malloc(sizeof(N));
		p->info = x;
		p->next = NULL;
		if (!head)
		{
			head = p;
			q = p;
		}
		else
		{
			q->next = p;
			q = p;
		}
	}
	return head;
}
void display(N* head)
{
	N *p=head;
	while (p)
	{
		if (p->next)
			printf("%d ", p->info);
		else
			printf("%d\n",p->info);
		p = p->next;
	}
}
N *insert(N* head,int x)
{
	N *p,*q=head,*qq=head->next;
	p = (N*)malloc(sizeof(N));
	p->info = x;
	if (p->info <= head->info)
	{
		p->next = head;
		head = p;
		return head;
	}
	while (qq)
	{
		if (p->info >= q->info && p->info <= qq->info)
		{
			p->next = qq;
			q->next = p;
			break;
		}
		else
		{
			q = qq;
			qq = qq->next;
		}
	}
	if (!qq)
	{
		q->next = p;
		p->next = NULL;
	}
	return head;
}
int main()
{
	N *h;
	int m, n;
	while (scanf_s("%d%d", &n, &m) != EOF)
	{
		if (n == 0 && m == 0)	return 0;
		h = init();
		h = creat(h, n);
		h = insert(h, m);
		display(h);
	}
	return 0;
}

下面是通过移动数组的元素进行:

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
int main()
{
	int a[110], n, t, i,  m;
	while (scanf_s("%d%d", &n, &m) != EOF)
	{
		if (m == 0 && n == 0)return 0;
		t = -1;
		memset(a, 0, sizeof(a));
		if (m == 0 && n == 0)	return 0;
		for (i = 0; i < n; i++)
		{
			scanf_s("%d", &a[i]);
			if (a[i] < m)
			{
				t = i;
			}
		}
		if (t == -1)
		{
			for (i = n; i >= 1; i--)
			{
				a[i] = a[i - 1];
			}
			a[0] = m;
		}
		else if(t<n-1)
		{
			for (i = n; i >= t + 1; i--)
			{
				a[i] = a[i - 1];
			}
			a[t + 1] = m;
		}
		else if (t == n - 1)
		{
			a[n] = m;
		}
		for (i = 0; i <= n; i++)
		{
			if (i != n)
			{
				printf("%d ", a[i]);
			}
			else
			{
				printf("%d\n", a[i]);
			}
		}
	}
	return 0;
}

上面的是用数组写的。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
引用\[2\]提供了关于如何在杭电OJ上使用C语言进行题目刷题的步骤。首先,你需要打开百度并搜索“杭电OJ”,然后进入官网进行注册。在注册界面上填写完整的信息后点击提交。接下来,你可以使用你的用户名和密码登录账号。进入刷题界面后,你可以选择C语言作为答题语言,并将代码粘贴到答题界面中。然后你可以查看答案是否正确。如果你不小心离开了界面,你可以通过点击红线圈出部分或者点击右上方的用户名进入用户界面来查看你的题目是否正确。\[2\] 引用\[1\]提供了一段C语言代码,但是没有明确指出这段代码的作用和题目的具体要求。如果你能提供更多关于杭电OJ1098题目的信息,我将能够为你提供更准确的帮助。 #### 引用[.reference_title] - *1* [杭电OJ 2007 C语言版 已通过](https://blog.csdn.net/m0_56912916/article/details/119041984)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* *3* [杭电OJ刷题指南(ACM)](https://blog.csdn.net/qq_38769551/article/details/101510000)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值