I have to use the the following file shuffle.csv to identify which parish from the most populated county has the least people. It is done line by line, for instance:
county A, parish B, Population B
county A, parish C, Population C
county A -> parish B or C -> Population B or C
If ( pop C < pop B ) county A -> parish C -> Population C
county A -> population + = Pop C
The most populated county is placed in the root of the linked list and then fprintf("output.csv"... ), in each interaction ( line by line ) evaluation til that line.
All the counties are added.
The least populated parish from the corresponding county is updated.
It very easy but I cannot spot the bug. It compiles well but when I run it the output, which is placed in a file named output.csv, is wrong. I have spent at least 5 hours revising the code, debugging, testing, breakpoints and I cant find the little *****r xD. I would appreciate it if you could help me out.
Nothing is stopping you from continuing with your testing cadence.
If updates are released every 2 weeks instead of 4, and you test once every 4 weeks, the exact same amount of patches will still be available for you in those 4 weeks.
For example:
Before
4th week - patch 1, 2, 3, 4
After
2nd week - patch 1 and 2
4th week - patch 3 and 4
Still the same amount after 4.
Everyone else has said it. I'm gonna say it - you don't know what you're talking about.
I do. I have two laptops. One work, one personal. I have access to two more laptops - both personal. At home I manually update my personal laptop when I see on Neowin that there is an update - I carry on and only apply the updates when I am ready. My work one only updates when my workplace decides to send it - I carry on and only apply the updates (when they actually arrive, which is usually days after the release) when I switch off the laptop at the end of the day as usual. The two other personal laptops only get updated when I get to it which is rarely - the people who own them carry on using them until I get to it and update them.
All of the browsers on all laptops are configured to restore the tabs when launched.
Google and Microsoft have changed from 6 weeks to 4, and it looks like it's going to move to 2. None of these changes affect how any of these browsers on the laptops are used. Not one jot.
My advice to you is stop panicking whenever you see an update. Just carry on with what you're doing. This even benefits you in a way - from your comment you sound like you don't like the changes or the frivolous new features - great - then carry on as before!
Question
pinprick
http://pastebin.com/BBHxd0iY
I have to use the the following file shuffle.csv to identify which parish from the most populated county has the least people. It is done line by line, for instance:
county A, parish B, Population B
county A, parish C, Population C
county A -> parish B or C -> Population B or C
If ( pop C < pop B ) county A -> parish C -> Population C
county A -> population + = Pop C
The most populated county is placed in the root of the linked list and then fprintf("output.csv"... ), in each interaction ( line by line ) evaluation til that line.
All the counties are added.
The least populated parish from the corresponding county is updated.
It very easy but I cannot spot the bug. It compiles well but when I run it the output, which is placed in a file named output.csv, is wrong. I have spent at least 5 hours revising the code, debugging, testing, breakpoints and I cant find the little *****r xD. I would appreciate it if you could help me out.
Input file structure:
District , county , parish, population
Grande Porto, Vila do Conde, Rio Mau, 1907
Output file structure:
fprintf( stdout, "%s, %s, %d\n", base->root->minusParish->parishName, base->root->countyName, base->root->minusParish->population);
Arcos, Vila do Conde, 869
...
Ferreiro, Vila do Conde, 660
...
Outeiro Maior, Vila do Conde, 378
...
It just prints Vila do Conde parish and it shouldn't.
HEADER
[b][u][color=#b22222]MAIN[/color][/u][/b]
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include "lista.h"
county* createCounty( char *name, int people ) {
county *ptr;
if ( ( ptr = ( county *) malloc( sizeof(county) * 1 ) ) == NULL ) return NULL;
ptr->countyName = name;
ptr->population = people;
ptr->next = NULL;
return ptr;
}
parish* createParish ( char *name, int people ) {
parish *ptr;
if ( ( ptr = ( parish *) malloc( sizeof(parish) * 1 ) ) == NULL ) return NULL;
ptr->parishName = name;
ptr->population = people;
return ptr;
}
FILE* readlnVeriPlace( FILE *input, core *listCore) {
int i;
int people;
county *countyList, *foundAddress;
parish *parishList;
char *countyMalloc;
char *parishMalloc;
char ch;
int position;
if ( input == NULL || listCore == NULL ) return NULL;
parishMalloc = (char *) malloc ( sizeof(char) * 50 );
countyMalloc = (char *) malloc ( sizeof(char) * 50 );
if ( parishMalloc == NULL || countyMalloc == NULL ) return input;
// READLINE
while ( ( ch = fgetc(input) ) != ',' );
i = 0;
while ( ( ch = fgetc(input) ) != ',' ) {
countyMalloc[i] = ch;
i++;
}
countyMalloc[i] = '\0';
i = 0;
while ( ( ch = fgetc(input) ) != ',' ) {
parishMalloc[i] = ch;
i++;
}
parishMalloc[i] = '\0';
fscanf(input, "%d", &people);
while ( fgetc(input) != '\n' && !feof(input)) ;
//ENDREADLINE
foundAddress = list_search( listCore, countyMalloc, &position);
if ( foundAddress != NULL ) {
list_assign( listCore, position, &parishMalloc, people);
free(countyMalloc);
}
else {
parishList = createParish ( parishMalloc, people );
countyList = createCounty ( countyMalloc, people );
countyList->minusParish = parishList;
foundAddress = countyList;
if ( listCore->numberCounties == 0 ) list_insert( listCore, -1, countyList);
}
list_sort( listCore, position, foundAddress);
return input;
}
int main( int argc, const char *argv[] ) {
FILE *input;
FILE *output;
core *base;
if ( argc != 2 ) {
fprintf( stdout, "%s shuffle.csv\n", argv[0] );
exit(1);
}
if ( ( input = fopen( argv[1], "r") ) == NULL ) {
fprintf( stdout, "Not possible to open the file.\n");
exit(2);
}
if ( ( output = fopen ( "output.csv", "w") ) == NULL ) exit(3);
if ( ( base = (core *) malloc( sizeof(core) * 1) ) == NULL ) exit (4);
base->numberCounties = 0;
base->root = NULL;
while ( !feof(input) ) {
input = readlnVeriPlace( input, base );
fprintf( stdout, "%s, %s, %d\n", base->root->minusParish->parishName, base->root->countyName, base->root->minusParish->population);
}
return 0;
}
[/CODE]
[color=#b22222][b][u]Function Library[/u][/b][/color]
#include "lista.h"
#include <string.h>
#include <stdlib.h>
#include <stdio.h>
int list_assign( core *l, int pos, char **str, int people)
{
int i = 0;
county *aux;
if (l == NULL || pos < 0)
return -1;
aux = l->root;
for (i = 0; i < pos && aux != NULL; i++)
aux = aux->next;
if (aux == NULL)
return -1;
aux->population += people;
if ( people < aux->minusParish->population ) {
aux->minusParish->population = people;
free(aux->minusParish->parishName);
aux->minusParish->parishName = *str;
} else free(*str);
return pos;
}
int list_insert( core *l, int pos, county *curr)
{
int i = 0;
county *temp;
if (l == NULL || pos < -1 || pos >= l->numberCounties) return -1;
temp = l->root;
if (curr == NULL) return -1;
l->numberCounties++;
if(pos == -1)
{
if (temp == NULL) l->root = curr;
else
{
while (temp->next != NULL) temp = temp->next;
temp->next = curr;
}
return l->numberCounties-1;
}
if (pos == 0)
{
curr->next = temp;
l->root = curr;
return pos;
}
for (i = 0; i < pos-1 && temp != NULL; i++) temp = temp->next;
curr->next = temp->next;
temp->next = curr;
return pos;
}
county* lista_removeToSort(core *l, int pos)
{
int i = 0;
county *prev, *curr;
if (l == NULL || pos < 0 || pos >= l->numberCounties) return NULL;
curr = l->root;
l->numberCounties--;
if(pos == 0)
{
l->root = curr->next;
curr->next = NULL;
return curr;
}
for( i = 0; i < pos && curr->next; i++)
{
prev = curr;
curr = curr->next;
}
prev->next = curr->next;
curr->next = NULL;
return curr;
}
county * list_search( core *l, char* str, int *pos)
{
int i = 0;
county *aux;
if( l == NULL ) return NULL;
for (aux = l->root; aux != NULL; aux = aux->next, i++)
{
if ( strcmp( aux->countyName, str) == 0) {
*pos = i;
return aux;
}
}
*pos = -1;
return NULL;
}
int list_sort( core *l, int posiVerifi, county *foundAddr)
{
county *ptr;
int i = 0;
if ( l == NULL ) return -1;
if ( l->root == NULL || l->numberCounties == 1) return 0;
if ( posiVerifi != -1 ) foundAddr = lista_removeToSort( l, posiVerifi);
for ( ptr = l->root; ptr != NULL; ptr = ptr->next, i++ ) {
if ( ptr->population < foundAddr->population ) {
list_insert( l, i, foundAddr);
}
}
list_insert( l, -1, foundAddr);
return 0;
}[/CODE]
Link to comment
https://www.neowin.net/forum/topic/1078483-c-step-linked-list-analysis/Share on other sites
6 answers to this question
Recommended Posts