How to generate different permutations of n char array?
ex : for n= 3, and basic string = abc
bca
cab
bac
cab
.....
...
.. 27 6504
onkar wrote: How to generate different permutations of n char array? ex : for n= 3, and basic string = abc bca cab bac cab .... ..
.
Go see Google Groups - search comp.lang.c for 'permutations' - finds 250+
results
--
==============
Not a pedant
==============
onkar said: How to generate different permutations of n char array? ex : for n= 3, and basic string = abc bca cab bac cab
Think of your array as being in two parts - the left part and the right
part. Initially, the left part is empty. (To keep track, just store the
number of elements in the left part.)
IF n - left > 0
take the right part, and rotate it one place.
Now recurse, for example Permute(s, n, left + 1).
Now rotate it back again.
ELSE
You have a permutation.
END IF
Have a go at it; if you get stuck, show us your best attempt and we'll do
what we can to help you fix it up.
--
Richard Heathfield
"Usenet is a strange place" - dmr 29/7/1999 http://www.cpax.org.uk
email: rjh at above domain (but drop the www, obviously)
onkar wrote: How to generate different permutations of n char array? ex : for n= 3, and basic string = abc bca cab bac cab .... ..
.
Is the array allowed to contain the same character more than once ?
If yes do you want all printed permutations to look different from
each other or are repeats ok ?
Richard Heathfield wrote: Think of your array as being in two parts - the left part and the right part. Initially, the left part is empty. (To keep track, just store the number of elements in the left part.)
IF n - left > 0 take the right part, and rotate it one place. Now recurse, for example Permute(s, n, left + 1). Now rotate it back again. ELSE You have a permutation. END IF
Have a go at it; if you get stuck, show us your best attempt and we'll do what we can to help you fix it up.
I write a function to populate the permutations based on an original
string. But it seems that I don't make the logic correct, the function
can not get all the permutations. It can only get a part of them,
others are missed. Comments are welcome, thanks in advance!
#include <string.h>
#include <stdlib.h>
int pmtgen(char *dest[], const char *src)
{
const int len = strlen(src);
char *p = malloc(len + 1);
int i, j, k;
int cnt = 0;
char c;
strcpy(p, src);
strcpy(*dest++, p);
cnt++; /*the original string*/
for (i = 0; i < len; ++i){
for (j = i + 1; j < len; ++j){ /*exchanging*/
p[i] = p[i] + p[j];
p[j] = p[i] - p[j];
p[i] = p[i] - p[j];
strcpy(*dest++, p);
cnt++;
strcpy(p, src);
}
if (i != 0 && i != 1){ /*inserting a char at the begining*/
c = p[i];
for (k = i; k > 0; --k){
p[k] = p[k - 1];
}
p[0] = c;
strcpy(*dest++, p);
cnt++;
strcpy(p, src);
}
if (i != len - 1 && i != len - 1 - 1){ /*appending a char at
the end*/
c = p[i];
for (k = i; k < len - 1; ++k){
p[k] = p[k + 1];
}
p[len - 1] = c;
strcpy(*dest++, p);
cnt++;
strcpy(p, src);
}
}
free(p);
return cnt;
}
#include <stdio.h>
#define ROW 12
#define COL 5
int main(void)
{
char *a[ROW];
int cnt;
int i, j;
for (j = 0; j < ROW; j++){
a[j] = malloc(COL);
if (!a[j]){
return 0;
}
}
cnt = pmtgen(a, "abc");
printf("%d permutations: ", cnt);
for (i = 0; i < ROW; i++){
printf("%s\t", a[i]);
}
for (j = 0; j < ROW; j++){
free(a[j]);
}
printf("\n");
return 0;
}
$ gcc -g -W -Wall -pedantic -ansi test.c
$ ./a.out
6 permutations: abc bac cba bca acb cab
$
lovecreatesbeau ty
lovecreatesbeau ty said:
<snip> I write a function to populate the permutations based on an original string. But it seems that I don't make the logic correct, the function can not get all the permutations. It can only get a part of them, others are missed. Comments are welcome, thanks in advance!
<snip>
cnt = pmtgen(a, "abc");
<snip>
$ gcc -g -W -Wall -pedantic -ansi test.c $ ./a.out 6 permutations: abc bac cba bca acb cab
You appear to have found six permutations of the three characters. Which
permutations do you think you missed?
--
Richard Heathfield
"Usenet is a strange place" - dmr 29/7/1999 http://www.cpax.org.uk
email: rjh at above domain (but drop the www, obviously)
lovecreatesbeau ty wrote: I write a function to populate the permutations based on an original string. But it seems that I don't make the logic correct, the function can not get all the permutations. It can only get a part of them, others are missed. Comments are welcome, thanks in advance!
<snip> for (i = 0; i < len; ++i){ for (j = i + 1; j < len; ++j){ /*exchanging*/ p[i] = p[i] + p[j]; p[j] = p[i] - p[j]; p[i] = p[i] - p[j];
What advantage does that have over:
tmp = p[i];
p[i] = p[j];
p[j] = tmp; ?
You save one declaration, but you add 3 arithmetic
operations, 4 array dereferences, and you make the
code less clear.
Bill Pursell schrieb: lovecreatesbeau ty wrote:
I write a function to populate the permutations based on an original string. But it seems that I don't make the logic correct, the function can not get all the permutations. It can only get a part of them, others are missed. Comments are welcome, thanks in advance!
<snip>
for (i = 0; i < len; ++i){ for (j = i + 1; j < len; ++j){ /*exchanging*/ p[i] = p[i] + p[j]; p[j] = p[i] - p[j]; p[i] = p[i] - p[j];
What advantage does that have over: tmp = p[i]; p[i] = p[j]; p[j] = tmp; ?
You save one declaration, but you add 3 arithmetic operations, 4 array dereferences, and you make the code less clear.
In addition, you risk signed overflow -- p is a char * and
char could be effectively signed char.
Cheers
Michael
--
E-Mail: Mine is an /at/ gmx /dot/ de address.
Richard Heathfield wrote: $ gcc -g -W -Wall -pedantic -ansi test.c $ ./a.out 6 permutations: abc bac cba bca acb cab
You appear to have found six permutations of the three characters. Which permutations do you think you missed?
$ gcc test.c
$ ./a.out
11 permutations: abcd bacd cbad dbca bcda acbd adcb
acdb abdc cabd dabc
$ gcc test.c
$ ./a.out
17 permutations: abcde bacde cbade dbcae ebcda bcdea acbde
adcbe aecdb acdeb abdce abedc cabde abdec abced dabce
eabcd
$
When the length of the base string is 4 or 5 (or more than 3, I guess),
e.g. "abcd" or "abcde", the result is not correct. For
"abcd", there should be total 24 permutations, for "abcde" 120
permutations (A(m,n) = n! / (n - m)!). I will continue to improve it.
Thanks.
lovecreatesbeau ty
pemo wrote: onkar wrote: How to generate different permutations of n char array? ex : for n= 3, and basic string = abc bca cab bac cab .... ..
.
Go see Google Groups - search comp.lang.c for 'permutations' - finds 250+ results
Just give them the code already... http://groups.google.com/group/comp....c0260bb56e83f2
--
Peter This thread has been closed and replies have been disabled. Please start a new discussion. Similar topics |
by: Mudge |
last post by:
Please, someone, tell me why OO in PHP is better than procedural.
|
by: Talin |
last post by:
I'm sure I am not the first person to do this, but I wanted to share
this: a generator which returns all permutations of a list:
def permute( lst ):
if len( lst ) == 1:
yield lst
else:
head = lst
for x in permute( lst ):
yield head + x
|
by: Jack Middleton |
last post by:
Hi!
I'm lookin for a faster permutation algorithm for matrices. I know that
it can be done with multiplying a matrix with a permutation matrix. It
just seems a waste to iterate through all those zeroes. Is there an
algorithm for matrixes that is optimized just for permutations? The
matrices that I use are fairly small (around 6*6) and I only use
positive integers as elements.
Thanks for help,
|
by: user |
last post by:
Hello
I have Array of 50 ints. I want to receive random permutation, so
in each int will be different number from 0-49.
Is there any class for permutation ?
Thanx
Michal
|
by: Rajesh |
last post by:
Hello Everybody,
Can anybody help me in writing a C program to generate and print all
possible combinations of n numbers.
For eg. for 3 numbers(1,2,3) there turn out 3! combinations.
(1,2,3), (1,3,2), (2,1,3), (2,3,1), (3,1,2), (3,2,1).
| |
by: weidongtom |
last post by:
Hi,
I have been working at this problem, and I think I need a permutation
algorithm that does
the following:
Given a list of elements that are either a character or a character
follows by a number, e.g.
|
by: badcrusher10 |
last post by:
Hello.
I'm having trouble figuring out what to do and how to do.. could someone explain to me what I need to do in order to work?
THIS IS WHAT I NEED TO DO:
Professor Snoop wants a program that will randomly generate 10 unique random numbers. Your job is to write a program that produces random permutations of the numbers 1 to 10. “Permutation” is a mathematical name for an arrangement. For example, there are six permutations of the...
|
by: xirowei |
last post by:
Let's say i create a String array that store 4 Alphabets {"A","B","C","D"}
How can i get the result if i need permutation of 4P3 and 4P2?
I had refer to many examples from the internet, but those examples cannot compute n selection from m elements. They only able to computer permutation of m elements without selection e.g. 4P4.
Hence i need guideline in how to compute this kind of permutation.
If i use manual calculation of 4P3...
|
by: 249740 |
last post by:
Write a program that reads N phrases and determines if one phrase is a
permutation of the other. For example: Phrase 1 is: “One World One Dream” Phrase 2 is: “World One One Dream”. Then the output should say that phrase 1 is permutation of phrase 2. Note that spaces/tabs are not counted as characters.
Sample Input:
3
One World One Dream
World One One Dream
No World No Dream
Sample Output:
Phrase 1 is permutation of Phrase 2
|
by: marktang |
last post by:
ONU (Optical Network Unit) is one of the key components for providing high-speed Internet services. Its primary function is to act as an endpoint device located at the user's premises. However, people are often confused as to whether an ONU can Work As a Router. In this blog post, we’ll explore What is ONU, What Is Router, ONU & Router’s main usage, and What is the difference between ONU and Router. Let’s take a closer look !
Part I. Meaning of...
|
by: Oralloy |
last post by:
Hello folks,
I am unable to find appropriate documentation on the type promotion of bit-fields when using the generalised comparison operator "<=>".
The problem is that using the GNU compilers, it seems that the internal comparison operator "<=>" tries to promote arguments from unsigned to signed.
This is as boiled down as I can make it.
Here is my compilation command:
g++-12 -std=c++20 -Wnarrowing bit_field.cpp
Here is the code in...
| |
by: Hystou |
last post by:
Overview:
Windows 11 and 10 have less user interface control over operating system update behaviour than previous versions of Windows. In Windows 11 and 10, there is no way to turn off the Windows Update option using the Control Panel or Settings app; it automatically checks for updates and installs any it finds, whether you like it or not. For most users, this new feature is actually very convenient. If you want to control the update process,...
|
by: tracyyun |
last post by:
Dear forum friends,
With the development of smart home technology, a variety of wireless communication protocols have appeared on the market, such as Zigbee, Z-Wave, Wi-Fi, Bluetooth, etc. Each protocol has its own unique characteristics and advantages, but as a user who is planning to build a smart home system, I am a bit confused by the choice of these technologies. I'm particularly interested in Zigbee because I've heard it does some...
|
by: isladogs |
last post by:
The next Access Europe User Group meeting will be on Wednesday 1 May 2024 starting at 18:00 UK time (6PM UTC+1) and finishing by 19:30 (7.30PM).
In this session, we are pleased to welcome a new presenter, Adolph Dupré who will be discussing some powerful techniques for using class modules.
He will explain when you may want to use classes instead of User Defined Types (UDT). For example, to manage the data in unbound forms.
Adolph will...
|
by: conductexam |
last post by:
I have .net C# application in which I am extracting data from word file and save it in database particularly. To store word all data as it is I am converting the whole word file firstly in HTML and then checking html paragraph one by one.
At the time of converting from word file to html my equations which are in the word document file was convert into image.
Globals.ThisAddIn.Application.ActiveDocument.Select();...
|
by: TSSRALBI |
last post by:
Hello
I'm a network technician in training and I need your help.
I am currently learning how to create and manage the different types of VPNs and I have a question about LAN-to-LAN VPNs.
The last exercise I practiced was to create a LAN-to-LAN VPN between two Pfsense firewalls, by using IPSEC protocols.
I succeeded, with both firewalls in the same network. But I'm wondering if it's possible to do the same thing, with 2 Pfsense firewalls...
|
by: adsilva |
last post by:
A Windows Forms form does not have the event Unload, like VB6. What one acts like?
| |
by: muto222 |
last post by:
How can i add a mobile payment intergratation into php mysql website.
| |