シングルチェーンテーブルの分割SDUT-2120
5534 ワード
データ構造実験のチェーンテーブル5:単一チェーンテーブルの分割Time Limit:1000 ms Memory limit:65536 Kに疑問がありますか?ここをクリック^^;タイトル記述N個の整数の順序を入力して1つの単一チェーンテーブルを創立して、この単一チェーンテーブルを2つのサブチェーンテーブルに分割して、第1のサブチェーンテーブルはすべての偶数を保存して、第2のサブチェーンテーブルはすべての奇数を保存しました.2つのサブチェーンテーブルのデータの相対順序は、元のチェーンテーブルと一致します.1行目の入力整数Nを入力する.2行目にN個の整数を順次入力します.出力第1行は、偶数チェーンテーブルと奇数チェーンテーブルの要素個数をそれぞれ出力する.2行目は偶数サブチェーンテーブルのすべてのデータを順次出力する.3行目は奇数サブチェーンテーブルのすべてのデータを順次出力します.サンプル入力
10 1 3 22 8 15 999 9 44 6 1001
サンプル出力
4 6 22 8 44 6 1 3 15 999 9 1001
10 1 3 22 8 15 999 9 44 6 1001
サンプル出力
4 6 22 8 44 6 1 3 15 999 9 1001
#include <bits/stdc++.h>
using namespace std;
struct node
{
int data;
node *next;
};
int main()
{
int n;
node *head1,*head2,*tail,*q,*p;
head1 = new node;
head1->next = NULL;
head2 = new node;
head2->next = NULL;
tail = head1;
cin>>n;
for(int i=0;i<n;i++)
{
q = new node;
cin>>q->data;
q->next = NULL;
tail->next = q;
tail = q;
}
int m = 0;
p = head1->next;
tail = head2;
q = head1;
while(p)
{
if(p->data%2 == 0)
{
q->next = p->next;
tail->next = p;
p->next = NULL;
tail = p;
p = q->next;
n--;
m++;
}
else
{
p = p->next;
q = q->next;
}
}
cout<<m<<" "<<n<<endl;
p = head2->next;
while(p)
{
if(p->next)
cout<<p->data<<" ";
else
cout<<p->data<<endl;
p = p->next;
}
p = head1->next;
while(p)
{
if(p->next)
cout<<p->data<<" ";
else
cout<<p->data<<endl;
p = p->next;
}
return 0;
}