Tilted Forum Project Discussion Community  

Go Back   Tilted Forum Project Discussion Community > Interests > Tilted Technology


 
 
LinkBack Thread Tools
Old 12-17-2006, 05:25 PM   #1 (permalink)
Junkie
 
zero2's Avatar
 
[c]Pointers

I kind of hate to ask so many times for help, but I'm really struggling at this.

I need to write a function, that allows a user to enter a string -- a pointer to char, and converts it to binary digit string or another pointer to char.

For instance, a user can type in any of the following, and that would be acceptable values.

a)"10100010001111"
b)" 001011100"
c)"11110010 "

My output is supposed to look like this:

Enter a binary string to continue or q to quit:
123ab46
The given string is not convertible!

Enter a binary string to continue or q to quit:
1010110100
The given string is converted to
1010110100

Enter a binary string to continue or q to quit:
q
Thank you!

So far this is what I got for my code, and after looking at it, I know it's really really wrong. I think where I'm going wrong is that instead of a loop, perhaps a switch statement would be better, but maybe I'm wrong. I also need to use pointers, but since I'm more comfortable with arrays, I want to try it with arrays, and later figure out how to do it with pointers.


Code:
#include <stdio.h>
/* Function Declaration */
int convertToBinaryVersionA(char cAry[]);

int main(void)
{
	int iA;
	char cAry[81];
	
	iA = convertToBinaryVersionA(cAry);
	return 0;
}

/**
* Function Name: convertBinaryVersionA()
*
*/
int convertToBinaryVersionA(char cAry1[])
{
	int i, j;
	int iSize;
	char cTest[81];
	int iVal;	
	
	printf("Enter a binary string to continue or q to quit: ");
	gets(cAry1);
	
	j = 0;
	
	for (i = 0; i < iSize; i++)
		{
			if ( cAry1 [i] == '0' || cAry1 [i] == '1' ) //testing if value is a binary digit
					 {
							cTest [j] = cAry1[i];//storing binary digit into array
							j++;
							iVal = 1;//return 1 if input is a binary #
	
						}
			else
				{    
                             for ( i= 0; i < iSize; i++)
	                            {
		                          printf("%3c", cAry1[i]);
	                            }
                            printf("The given string is not convertible");
					iVal = 0;//return 0 if input is not a binary #
				}
		}
      printf("The given string is converted to: ");	
	for ( j= 0; j < iSize; j++)
	{
		printf("%3c", cTest[j]);//values
	}
	return iVal;
}
zero2 is offline  
Old 12-18-2006, 06:50 AM   #2 (permalink)
Junkie
 
You are converting from binary to binary? That doesn't make much sense. If you are going from binary to decimal that is pretty easy. Just loop over the digits and add 1 to a counter if the digit is a 1. When the loop moves to the next digit multiply by 2.

Are you doing all these problems for a class?
Rekna is offline  
Old 12-20-2006, 09:09 PM   #3 (permalink)
Junkie
 
zero2's Avatar
 
Actually it looks like the formatting in my previous post where, what is acceptable values got messed up, but there are actually spaces in example b, and c, but it's hard to tell.

I need to store the values into a array/pointer, then store the values from the first array back into another array, with the condition that the values are binary digits.

So lets say a user enters: space, space, 1, 0, 1, 1, 0, 0

'', '', '1', '0', '1', '1', '0', '0'

The first array would grab the data such as:

cAry[0] = ''
cAry[1] = ''
cAry[2] = '1'
cAry[3] = '1'
cAry[4] = '0'
cAry[5] = '0'
cAry[6] = '\n'

The second character array, needs to grab only binary numbers:

cAryBinary[0] = '1'
cAryBinary[1] = '1'
cAryBinary[2] = '0'
cAryBinary[3] = '1'
cAryBinary[4] = '0'
cAryBinary[5] = '\n'

So far this is what I have, it's far from being done, but one problem I've come across, is how to have the program ask: Enter a binary string to continue or q to quit, and only when the q is entered does the program stop asking that question.

I was thinking of doing a while loop, that asks:

while (*(cPtr + 0) !=q )
do ...
but that doesn't seem to work.



Code:
#include <stdio.h>
#include <stdlib.h>

int main(void)
{
	int iSize;
	char *cPtr;
	

	printf("\nEnter estimate size of string ");
	scanf("%d", &iSize);
	getchar();//clears input buffer
	cPtr = (char * ) malloc (iSize * sizeof(char));
	printf("Enter a binary string to continue or q to quit:");
	gets(cPtr);

	if ( *(cPtr+ 0) == 'q' )
	{
		printf("Thank You!\n");
	}
	else if (*(cPtr + 0) == '0' || *(cPtr + 0) == '1' )
	{
		printf("The given string is converted to %s\n", cPtr);
	}
	else
	{
		printf("The given string is not convertible!\n");
	}
	return 0;

}
zero2 is offline  
Old 12-20-2006, 09:53 PM   #4 (permalink)
Junkie
 
Quote:
Originally Posted by zero2
Actually it looks like the formatting in my previous post where, what is acceptable values got messed up, but there are actually spaces in example b, and c, but it's hard to tell.

I need to store the values into a array/pointer, then store the values from the first array back into another array, with the condition that the values are binary digits.

So lets say a user enters: space, space, 1, 0, 1, 1, 0, 0

'', '', '1', '0', '1', '1', '0', '0'

The first array would grab the data such as:

cAry[0] = ''
cAry[1] = ''
cAry[2] = '1'
cAry[3] = '1'
cAry[4] = '0'
cAry[5] = '0'
cAry[6] = '\n'

The second character array, needs to grab only binary numbers:

cAryBinary[0] = '1'
cAryBinary[1] = '1'
cAryBinary[2] = '0'
cAryBinary[3] = '1'
cAryBinary[4] = '0'
cAryBinary[5] = '\n'

So far this is what I have, it's far from being done, but one problem I've come across, is how to have the program ask: Enter a binary string to continue or q to quit, and only when the q is entered does the program stop asking that question.

I was thinking of doing a while loop, that asks:

while (*(cPtr + 0) !=q )
do ...
but that doesn't seem to work.



Code:
#include <stdio.h>
#include <stdlib.h>

int main(void)
{
	int iSize;
	char *cPtr;
	

	printf("\nEnter estimate size of string ");
	scanf("%d", &iSize);
	getchar();//clears input buffer
	cPtr = (char * ) malloc (iSize * sizeof(char));
	printf("Enter a binary string to continue or q to quit:");
	gets(cPtr);

	if ( *(cPtr+ 0) == 'q' )
	{
		printf("Thank You!\n");
	}
	else if (*(cPtr + 0) == '0' || *(cPtr + 0) == '1' )
	{
		printf("The given string is converted to %s\n", cPtr);
	}
	else
	{
		printf("The given string is not convertible!\n");
	}
	return 0;

}
There are lots of ways to do that but yours is close to right. You don't need the +0, and i'd avoid using the * operator. Instead do something like

//input cptr

while(cptr[0]!='q' || cptr[0]!='Q')
{
//process string

//input cptr
}


Also just an fyi. the command break; will exit the innermost loop and the command exit(int retval); will quit the program and return the value retval to the calling program. These can be used for termination.

Sorry for not giving you lots of code but I think it's important that you learn the stuff yourself by trying things out.
Rekna is offline  
Old 12-21-2006, 08:04 PM   #5 (permalink)
Junkie
 
zero2's Avatar
 
Thank You Rekna. I liked the code that you had where you test for lowercase q or uppercase Q, that was something that I didn't think off.

I also ran into a problem, when I added the while loop, I wasn't able to ask the user the size of the pointer after the first iteration.

So my output looked like this:
=====First Time Run==========
Enter an estimate of size of string: 7
Enter a binary string to continue or q to quit:
123ab46
The given string is not convertible!
======Second Time Run==========
Enter a binary string to continue or q to quit: 7
123ab46
The given string is not convertible!

Here's my latest code, hopefully I'm doing something right here:

Code:
#include<stdio.h>
#include<stdlib.h>

void convertToBinaryVersionA();

int main(void)
{
	convertToBinaryVersionA();
		return 0;
}

void convertToBinaryVersionA()
{
	char *cPtr;
	int iSize;
	int i;
	char *cBinary;
	int j = 0;
	int iCount;
	
	printf("Enter an estimate of size of string: ");
	scanf("%d", &iSize);
	
	getchar();
	cPtr =  (char *) malloc (iSize * sizeof(char));
	printf("Enter a binary string to continue or q to quit: ");
	gets(cPtr);
	
	cBinary = (char *) malloc (iSize * sizeof(char));
	
	for (i = 0; i < iSize; i++)
		{
			if( * (cPtr + 0) == 'q' || * (cPtr + 0) == 'Q')
				{
					printf("Thank You!\n");
				}
			else if ( * (cPtr + i) == '0' || * (cPtr + i) == '1' )
				{
					cBinary[j] = cPtr[i];
					j++;
					iCount = 0;
				}
			else
				{
					iCount = 1;
					
				}
		}
		if ( iCount == 0 )
		{
			printf("The converted string is: %s", cBinary);
		}
		else
		{
			printf("The inputed string is not convertible!\n");
		}
	
	return;
}
zero2 is offline  
Old 12-21-2006, 09:23 PM   #6 (permalink)
Junkie
 
Quote:
Originally Posted by zero2
Thank You Rekna. I liked the code that you had where you test for lowercase q or uppercase Q, that was something that I didn't think off.

I also ran into a problem, when I added the while loop, I wasn't able to ask the user the size of the pointer after the first iteration.

So my output looked like this:
=====First Time Run==========
Enter an estimate of size of string: 7
Enter a binary string to continue or q to quit:
123ab46
The given string is not convertible!
======Second Time Run==========
Enter a binary string to continue or q to quit: 7
123ab46
The given string is not convertible!

Here's my latest code, hopefully I'm doing something right here:

Code:
#include<stdio.h>
#include<stdlib.h>

void convertToBinaryVersionA();

int main(void)
{
	convertToBinaryVersionA();
		return 0;
}

void convertToBinaryVersionA()
{
	char *cPtr;
	int iSize;
	int i;
	char *cBinary;
	int j = 0;
	int iCount;
	
	printf("Enter an estimate of size of string: ");
	scanf("%d", &iSize);
	
	getchar();
	cPtr =  (char *) malloc (iSize * sizeof(char));
	printf("Enter a binary string to continue or q to quit: ");
	gets(cPtr);
	
	cBinary = (char *) malloc (iSize * sizeof(char));
	
	for (i = 0; i < iSize; i++)
		{
			if( * (cPtr + 0) == 'q' || * (cPtr + 0) == 'Q')
				{
					printf("Thank You!\n");
				}
			else if ( * (cPtr + i) == '0' || * (cPtr + i) == '1' )
				{
					cBinary[j] = cPtr[i];
					j++;
					iCount = 0;
				}
			else
				{
					iCount = 1;
					
				}
		}
		if ( iCount == 0 )
		{
			printf("The converted string is: %s", cBinary);
		}
		else
		{
			printf("The inputed string is not convertible!\n");
		}
	
	return;
}

Don't ask the user the size of the string, use input should always be kept to a minimum. Instead just create a buffer for the string that is bigger than a user would enter (say 1000 or 10000 characters). Asking the user what size the string is gives the user an unnecessary burden. In addition if the user is wrong and they make a string that is to small then your program will more than likely crash, or worse a malicious user could use that program to do bad things. There are lots of issues dealing with buffer overrun errors that you shouldn't worry about at this time. That is a much more advanced topic. For now just use a very large array that way you don't have to use malloc instead just use an array.

Also if and when you use malloc make sure you free the memory also. Failure to free it causes memory leaks.
Rekna is offline  
 

Tags
cpointers


Posting Rules
You may not post new threads
You may not post replies
You may not post attachments
You may not edit your posts

BB code is On
Smilies are On
[IMG] code is On
HTML code is Off
Trackbacks are On
Pingbacks are On
Refbacks are On



All times are GMT -8. The time now is 05:52 PM.

Tilted Forum Project

Powered by vBulletin® Version 3.8.7
Copyright ©2000 - 2024, vBulletin Solutions, Inc.
Search Engine Optimization by vBSEO 3.6.0 PL2
© 2002-2012 Tilted Forum Project

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 312 313 314 315 316 317 318 319 320 321 322 323 324 325 326 327 328 329 330 331 332 333 334 335 336 337 338 339 340 341 342 343 344 345 346 347 348 349 350 351 352 353 354 355 356 357 358 359 360