Exetools  

Go Back   Exetools > General > General Discussion

Notices

 
 
Thread Tools Display Modes
Prev Previous Post   Next Post Next
  #5  
Old 08-27-2006, 01:00
JuneMouse
 
Posts: n/a
well basically the design is not good but you can make it work like that if you just
assign the increment values correctly no need to have fixed string length
you can do variable string length as long as you take care not to overflow your malloc size

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

int main(void) 
{ 
   char * pi; 
  int i,r,len[5]= {0},wen =0 ,foo=0; 
   puts("start"); 
   pi = (char *) malloc(50 * sizeof(char)); 
    
    
  for(i = 0; i < 5; i++) 
  { 
  r = scanf("%s%n",&pi[wen],&len[i]); //len[i] will hold the length of input
    if(r != 1) 
    break;
	if(i==0)
    	wen = wen + len[i]+ 1; //first time we need to add a 0 terminator
        else
	wen = wen + len[i];    // from second time no need coz it will point right
  
} 
      i = 0; 
      while(i < 5) 
      { 
        printf("%s",&*(pi + foo )); 
        putchar('\n'); 
	if(i==0)
             foo = foo + len[i] + 1; //same as above skip 0 terminator
	else
	foo = foo + len[i];    // no need second time onwards
	i++;
          } 
    
          free(pi); 
          puts("Done!"); 
          
      


  getch(); 
  return 0; 

}
output

Code:
start
rrrrrrrrrrrrrrrrrrrrr
ttttttttttttttttttttttt
yyyyyy
zest
malloc
rrrrrrrrrrrrrrrrrrrrr
ttttttttttttttttttttttt
yyyyyy
zest
malloc
Done!
but ill advise you get a c book or c++ book and leaf through them

have fun
Reply With Quote
 


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 Off
HTML code is Off



All times are GMT +8. The time now is 16:08.


Always Your Best Friend: Aaron, JMI, ahmadmansoor, ZeNiX, chessgod101
( Since 1998 )