Проблемы при использовании кругового связного списка для часов
Итак, я получил эту работу, которую мне нужно дать о создании цифровых часов. Пользователь устанавливает количество поклонов, и каждый узел равен 1/n секунды, а N - это число узлов, которые ставит пользователь. После этого меня вызывают, чтобы сделать 3 указателя:
- один на секунды
- один на минуты
- один на несколько часов
Указатель Seconds должен выполнять все узлы в круговой ссылке. Для полного поворота указатель минут должен начать перемещаться к следующему узлу, и после общего количества 60 ходов указателя минут, после него должен следовать часовой указатель. Часы должны делать следующие вещи:
Пользователь может установить часы обратно на ноль: 00:00:00;
Пользователь может установить часы с точностью до секунд.
Программа должна показывать часы после каждого занятия.
Пользователь может запрограммировать часы для будильника, в котором часы показывают сообщение пользователю.
Он должен найти следующий час, чтобы его указатели (на часах, а не на программе) выровнялись (например: 12:00,01:05,02:10,03:15 и т. Д.)
- программа завершает работу после освобождения памяти, оставшейся в нашем списке.
вот мой код, но у меня возникли некоторые трудности с ним.
#include<stdio.h>
#include<stdlib.h>
int counter=0;
typedef struct Node
{
int data;
struct Node *next;
}node;
void insert(node *pointer, int data)
{
node *start = pointer;
/* Iterate through the list till we encounter the last node.*/
while(pointer->next!=start)
{
pointer = pointer -> next;
}
/* Allocate memory for the new node and put data in it.*/
pointer->next = (node *)malloc(sizeof(node));
pointer = pointer->next;
pointer->data = data;
pointer->next = start;
}
void print(node *start,node *pointer)
{
if(pointer==start)
{
return;
}
printf("%d ",pointer->data);
print(start,pointer->next);
}
int main()
{
/* start always points to the first node of the linked list.
temp is used to point to the last node of the linked list.*/
node *start,*temp;
start = (node *)malloc(sizeof(node));
temp = start;
temp -> next = start;
/* Here in this code, we take the first node as a dummy node.
The first node does not contain data, but it used because to avoid handling special cases
in insert and delete functions.
*/
node *sec,*min,*hour;
int v,c,n;
printf("1. Insert N\n");
printf("2. Make Time Zero\n");
printf("3. Set Clock\n");
int query;
scanf("%d",&query);
if(query==1)
{
int data,i,n;
printf("Posa n thes\n");
scanf("%d",&n);
for (i = 0; i < 60*n; i++)
{
data = i;
insert(start,data);
printf("%d\n",i);
}
node *sec_copy;
sec_copy=start;
min=start;
hour=start;
while(n>0)
{
sec_copy=sec_copy->next;
n--;
c++;
if(c == 59*n)
{
min=min->next;
c=0;
v++;
}
if(v == 60)
{
hour=hour->next;
v=0;
}
}
}
printf("%d",sec->data);
if(query==2)
{
int timer;
timer=0;
printf("%.2d:%.2d:%.2d",timer,timer,timer);
}
if(query==3)
{
int h,m,s;
printf("Set me hours");
scanf("%d",&h);
h = h%24;
printf("Set me min");
scanf("%d",&m);
h = h+m/60;
m = m%60;
printf("Set me secs");
scanf("%d",&s);
h = h + s/3600;
m = m + s%3600;
s = s%60;
}
}
1 ответ
Как отметил Some programmer dude, для этого вам действительно нужно использовать отладчик.
Единственная причина, по которой я вижу segfault - это то, что вы звоните printf("%d",sec->data);
без инициализации sec
,
Вы также не инициализируете 'v' и 'c', и в вашем решении есть две переменные 'n'.