User Name Password Register
DaniWeb IT Discussion Community
All
What is DaniWeb IT Discussion Community?
You're currently browsing the C section within the Software Development category of DaniWeb, a massive community of 423,546 software developers, web developers, Internet marketers, and tech gurus who are all enthusiastic about making contacts, networking, and learning from each other. In fact, there are 3,983 IT professionals currently interacting right now! Registration is free, only takes a minute and lets you enjoy all of the interactive features of the site.
Please support our C advertiser: Programming Forums
Views: 7080 | Replies: 5
Join Date: Dec 2006
Posts: 1
Reputation: vijayr_singh is an unknown quantity at this point 
Rep Power: 0
Solved Threads: 0
vijayr_singh vijayr_singh is offline Offline
Newbie Poster

possible combination of a string

  #1  
Dec 13th, 2006
Hi friends...

I need to write a program in C which will print all the combinations of a string with non-repeating characters. Example: “Say” will have the following: S, a,y, Sa, Sy, aS,Sy, yS, ya, aSy,Sya,ySa and so on. The string length is not known. The string will be a command line argument to the program.


The code that i have goes below but its not giving me the desired output. the output that i m getting from this program is like

#############OUTPUT##################
Enter the string : say

sya
ysa
yas
ays
asy
say
##################################

#############DESIRED OUTPUT##################
Enter the string : say

s
a
y
sa
sy
as
ys
ay
ya
sya
ysa
yas
ays
asy
say
###########################################


###########PROGRAM################
  1. #include<stdio.h>
  2. #include<string.h>
  3. #include<alloc.h>
  4. #include<conio.h>
  5.  
  6.  
  7. void swap(char*,int);
  8. void gotoloop(char*,int);
  9.  
  10. void main()
  11. {
  12. char *ch;
  13. int i,j,k,l;
  14. ch=(char*)malloc(20);
  15. //clrscr();
  16. printf("Enter the string\n");
  17. gets(ch);
  18.  
  19. l=strlen(ch);
  20. gotoloop(ch,l);
  21.  
  22. return;
  23. }
  24.  
  25. void gotoloop(char *ch,int l)
  26. {
  27. int i,k;
  28. k=l;
  29.  
  30. if(l<=1)
  31. return;
  32.  
  33.  
  34. for(i=0;i<k;i++)
  35. {
  36. swap(ch,k);
  37. l--;
  38. gotoloop(ch,l);
  39. l++;
  40. if(k==2)
  41. printf("\n%s ",ch);
  42. }
  43.  
  44. }
  45.  
  46.  
  47. void swap(char *ch,int r)
  48.  
  49. {
  50. char c;
  51. int i;
  52.  
  53. c=ch[r-1];
  54. for(i=r-1;i>0;i--)
  55. ch[i]=ch[i-1];
  56. ch[0]=c;
  57. }


This is not like a normal permutation of string.

Can anyone help me on this ASAP.

Thanks in advance
Last edited by ~s.o.s~ : Dec 13th, 2006 at 10:44 am. Reason: Added code tags learn to use them yourself.
AddThis Social Bookmark Button
Reply With Quote  

Only community members can participate in forum threads. You must register or log in to contribute.

DaniWeb C Marketplace
Currently Active Users Viewing This Thread: 1 (0 members and 1 guests)

 

Thread Tools Display Modes

Similar Threads
Other Threads in the C Forum

All times are GMT -4. The time now is 5:56 pm.
Forum system based on vBulletin Copyright ©2000 - 2008, Jelsoft Enterprises Ltd.
©2003 - 2008 DaniWeb® LLC